SpringBoot使用GraphQL開發(fā)Web API實(shí)現(xiàn)方案示例講解
前言
傳統(tǒng)的Restful API 存在諸多的問題,首先它無法控制返回的字段,前端也無法預(yù)判后端的返回結(jié)果,另外不同的返回結(jié)果對(duì)應(yīng)不同的請(qǐng)求地址,這就導(dǎo)致了多次請(qǐng)求的問題。而GraphQL正是基于這樣的背景而構(gòu)建出來的API查詢語言,相對(duì)于傳統(tǒng)Restful API 它具有以下幾個(gè)優(yōu)點(diǎn):
- 靈活性:GraphQL 可以根據(jù)客戶端的需求靈活地查詢數(shù)據(jù),而不是像 RESTful API 那樣返回固定結(jié)構(gòu)的數(shù)據(jù)。
- 減少網(wǎng)絡(luò)請(qǐng)求:GraphQL 允許客戶端在一次請(qǐng)求中獲取多個(gè)資源,這有助于減少網(wǎng)絡(luò)請(qǐng)求的數(shù)量和提高性能。
- 強(qiáng)類型:GraphQL 有一種強(qiáng)類型系統(tǒng),客戶端可以在編譯時(shí)檢測(cè)到查詢中的錯(cuò)誤,這有助于減少運(yùn)行時(shí)錯(cuò)誤。
- 可緩存:GraphQL 具有可緩存性,這意味著服務(wù)器可以緩存查詢的結(jié)果,從而提高性能和可伸縮性。
- 文檔化:GraphQL 具有自我文檔化的能力,使得開發(fā)者可以快速了解 API 的結(jié)構(gòu)和功能。
Spring Boot中GraphQL的實(shí)現(xiàn)方案
如果后端語言為Java,那么GraphQL Java則是實(shí)現(xiàn)GraphQL的基礎(chǔ)庫。另外Spring已經(jīng)整合了GraphQL,如果項(xiàng)目中使用了Spring,那么更加推薦Spring GraphQL。
Spring GraphQL的開發(fā)總體分為如下幾個(gè)步驟
添加 Spring GraphQL 依賴項(xiàng)
在您的項(xiàng)目中添加 Spring GraphQL 依賴項(xiàng)。您可以通過 Maven 或 Gradle 等構(gòu)建工具來添加依賴項(xiàng)。例如,如果您使用 Maven,則可以添加以下依賴項(xiàng)
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-graphql</artifactId> </dependency>
定義 GraphQL Schema
在您的應(yīng)用程序中定義 GraphQL Schema。Schema 定義了可查詢的類型和字段。您可以使用 SDL(Schema Definition Language)或編程方式定義 Schema。
對(duì)于Spring Boot 工程來說schema文件放到resources/graphql/目錄下,文件名后綴graphqls,下面是我定義一個(gè)的簡(jiǎn)單的schema.graphqls。
它指定了兩個(gè)查詢實(shí)現(xiàn),author(id:Int)表示通過id查詢Author,allAuthors則表示查詢Author數(shù)組。
schema {
query: Query
}type Query {
author(id:Int): Author
allAuthors: [Author]
}type Author {
id:Int
firstName:String
lastName:String
email:String
birthdate:String
}
實(shí)現(xiàn)RuntimeWiringConfigurer
RuntimeWiringConfigurer是實(shí)現(xiàn)GraphQL獲取數(shù)據(jù)的核心,使用GraphQL并不能直接去掉Mybatis/Jpa這類持久層框架,從數(shù)據(jù)庫獲取數(shù)據(jù)仍然需要這類框架的支持。
而RuntimeWiringConfigurer則類似于Spring中的service層,它是實(shí)現(xiàn)基礎(chǔ)數(shù)據(jù)的核心。
以下是一個(gè)簡(jiǎn)單示例:
@Component public class AuthorWiring implements RuntimeWiringConfigurer { private final AuthorRepository authorRepository; public AuthorWiring(AuthorRepository authorRepository) { this.authorRepository = authorRepository; } @Override public void configure(RuntimeWiring.Builder builder) { builder.type("Query", typeWiring -> typeWiring .dataFetcher("allAuthors", environment -> authorRepository.findAll()) .dataFetcher("author", environment -> authorRepository.getReferenceById(environment.getArgument("id"))) } }
這里configure方法內(nèi)部分別定義了兩個(gè)DataFetcher對(duì)象,用來指定author和allAuthors查詢數(shù)據(jù)的方式,可以看出依然是通過JPA去查詢數(shù)據(jù)。
定義GraphQL Controller
我么定義GraphQLController用來接收web請(qǐng)求的入?yún)?,示例如下?/p>
@RestController @RequestMapping("graphql") public class GraphQLController { private final GraphQL graphQL; @Autowired public GraphQLController(GraphQlSource graphQlSource) { graphQL = graphQlSource.graphQl(); } @PostMapping("query") public ResponseEntity<Object> query(@RequestBody String query) { ExecutionResult result = graphQL.execute(query); return ResponseEntity.ok(result.getData()); } }
代碼中GraphQL對(duì)象是執(zhí)行查詢的入口,但GraphQL只有一個(gè)私有的構(gòu)造方法,所以不能直接注入,必須通過注入GraphQlSource的方式來獲取GraphQL對(duì)象。
注意在GraphQL中我們只能使用String來接收參數(shù),無法使用model對(duì)象,這是因?yàn)镚raph請(qǐng)求參數(shù)并不是json結(jié)構(gòu)。
測(cè)試Graph請(qǐng)求
我們創(chuàng)建一個(gè)graphql.http的文件,用于在idea中執(zhí)行http請(qǐng)求
### Send POST request with json body
POST http://localhost:8080/graphql/query
Content-Type: application/json{
author(id: 1) {
id
firstName
lastName
birthdate
}
}### Send POST request with json body
POST http://localhost:8080/graphql/query
Content-Type: application/json{
allAuthors {
id
firstName
lastName
birthdate
}
}
運(yùn)行author(id: 1) 的查詢,可以看到正常返回結(jié)果了。如果我們只需要 firstName和lastName兩個(gè)字段,那么在請(qǐng)求入?yún)⒅兄苯尤サ鬷d和birthdate就好了,而不用改動(dòng)任何后端代碼。
完整項(xiàng)目已上傳github ?? graphql-demo
到此這篇關(guān)于SpringBoot使用GraphQL開發(fā)Web API實(shí)現(xiàn)方案示例講解的文章就介紹到這了,更多相關(guān)SpringBoot GraphQL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?Boot?如何生成微信小程序短連接及發(fā)送短信在短信中打開小程序操作
最近遇到這樣的需求需要發(fā)送短信,通過短信中的短連接打開小程序操作,下面小編給大家分享Spring?Boot?如何生成微信小程序短連接發(fā)送短信在短信中打開小程序操作,感興趣的朋友跟隨小編一起看看吧2024-03-03java + dom4j.jar提取xml文檔內(nèi)容
這篇文章主要為大家詳細(xì)介紹了java + dom4j.jar提取xml文檔內(nèi)容,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08java微信公眾號(hào)支付開發(fā)之現(xiàn)金紅包
這篇文章主要為大家詳細(xì)介紹了java微信公眾號(hào)支付開發(fā)之現(xiàn)金紅包,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04Java實(shí)現(xiàn)儲(chǔ)存對(duì)象并按對(duì)象某屬性排序的幾種方法示例
這篇文章主要介紹了Java實(shí)現(xiàn)儲(chǔ)存對(duì)象并按對(duì)象某屬性排序的幾種方法,結(jié)合實(shí)例形式詳細(xì)分析了Java儲(chǔ)存對(duì)象并按對(duì)象某屬性排序的具體實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下2020-05-05SpringBoot配置類中@Configuration和@Bean的作用
這篇文章主要介紹了SpringBoot配置類中@Configuration和@Bean的作用,@Configuration 指明當(dāng)前類是一個(gè)配置類來替代之前的Spring配置文件,Spring boot的配置類,相當(dāng)于Spring的配置文件,需要的朋友可以參考下2023-11-11Spring?MVC中@Controller和@RequestMapping注解使用
這篇文章主要介紹了Spring?MVC中@Controller和@RequestMapping注解使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02為什么 Java 8 中不需要 StringBuilder 拼接字符串
java8中,編輯器對(duì)“+”進(jìn)行了優(yōu)化,默認(rèn)使用StringBuilder進(jìn)行拼接,所以不用顯示的使用StringBuilder了,直接用“+”就可以了。下面我們來詳細(xì)了解一下2019-05-05