溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

SpringBoot怎么使用GraphQL開發(fā)Web?API

發(fā)布時間:2023-04-04 13:36:28 來源:億速云 閱讀:132 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“SpringBoot怎么使用GraphQL開發(fā)Web API”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“SpringBoot怎么使用GraphQL開發(fā)Web API”吧!

前言

傳統(tǒng)的Restful API 存在諸多的問題,首先它無法控制返回的字段,前端也無法預(yù)判后端的返回結(jié)果,另外不同的返回結(jié)果對應(yīng)不同的請求地址,這就導(dǎo)致了多次請求的問題。而GraphQL正是基于這樣的背景而構(gòu)建出來的API查詢語言,相對于傳統(tǒng)Restful API 它具有以下幾個優(yōu)點:

  • 靈活性:GraphQL 可以根據(jù)客戶端的需求靈活地查詢數(shù)據(jù),而不是像 RESTful API 那樣返回固定結(jié)構(gòu)的數(shù)據(jù)。

  • 減少網(wǎng)絡(luò)請求:GraphQL 允許客戶端在一次請求中獲取多個資源,這有助于減少網(wǎng)絡(luò)請求的數(shù)量和提高性能。

  • 強類型:GraphQL 有一種強類型系統(tǒng),客戶端可以在編譯時檢測到查詢中的錯誤,這有助于減少運行時錯誤。

  • 可緩存:GraphQL 具有可緩存性,這意味著服務(wù)器可以緩存查詢的結(jié)果,從而提高性能和可伸縮性。

  • 文檔化:GraphQL 具有自我文檔化的能力,使得開發(fā)者可以快速了解 API 的結(jié)構(gòu)和功能。

Spring Boot中GraphQL的實現(xiàn)方案

如果后端語言為Java,那么GraphQL Java則是實現(xiàn)GraphQL的基礎(chǔ)庫。另外Spring已經(jīng)整合了GraphQL,如果項目中使用了Spring,那么更加推薦Spring GraphQL。

Spring GraphQL的開發(fā)總體分為如下幾個步驟

添加 Spring GraphQL 依賴項

在您的項目中添加 Spring GraphQL 依賴項。您可以通過 Maven 或 Gradle 等構(gòu)建工具來添加依賴項。例如,如果您使用 Maven,則可以添加以下依賴項

        <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。

對于Spring Boot 工程來說schema文件放到resources/graphql/目錄下,文件名后綴graphqls,下面是我定義一個的簡單的schema.graphqls。

它指定了兩個查詢實現(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
}

實現(xiàn)RuntimeWiringConfigurer

RuntimeWiringConfigurer是實現(xiàn)GraphQL獲取數(shù)據(jù)的核心,使用GraphQL并不能直接去掉Mybatis/Jpa這類持久層框架,從數(shù)據(jù)庫獲取數(shù)據(jù)仍然需要這類框架的支持。

而RuntimeWiringConfigurer則類似于Spring中的service層,它是實現(xiàn)基礎(chǔ)數(shù)據(jù)的核心。

以下是一個簡單示例:

@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)部分別定義了兩個DataFetcher對象,用來指定author和allAuthors查詢數(shù)據(jù)的方式,可以看出依然是通過JPA去查詢數(shù)據(jù)。

定義GraphQL Controller

我么定義GraphQLController用來接收web請求的入?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對象是執(zhí)行查詢的入口,但GraphQL只有一個私有的構(gòu)造方法,所以不能直接注入,必須通過注入GraphQlSource的方式來獲取GraphQL對象。

注意在GraphQL中我們只能使用String來接收參數(shù),無法使用model對象,這是因為Graph請求參數(shù)并不是json結(jié)構(gòu)。

測試Graph請求

我們創(chuàng)建一個graphql.http的文件,用于在idea中執(zhí)行http請求

### 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
  }
}

運行author(id: 1) 的查詢,可以看到正常返回結(jié)果了。如果我們只需要 firstName和lastName兩個字段,那么在請求入?yún)⒅兄苯尤サ鬷d和birthdate就好了,而不用改動任何后端代碼。

SpringBoot怎么使用GraphQL開發(fā)Web?API

SpringBoot怎么使用GraphQL開發(fā)Web?API

感謝各位的閱讀,以上就是“SpringBoot怎么使用GraphQL開發(fā)Web API”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對SpringBoot怎么使用GraphQL開發(fā)Web API這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI