Spring boot中apollo-kotlin基本使用(一个客户端使用多个graphql端点)

该博客介绍了如何在Springboot项目中集成Apollo-Kotlin,实现多GraphQL服务配置,并通过Gradle插件下载和管理schema文件。同时,展示了如何自动生成GraphQL客户端代码,并提供了下载schema文件的两种方法。此外,还展示了如何在项目中调用这些服务并处理异常。
摘要由CSDN通过智能技术生成

apollo-kotlin

一、新建Springboot项目
.
├── build.gradle.kts
└── src
    ├── main
    │   ├── graphql
    │   │   ├── service1
    │   │   │   ├── DemoQuery.graphql
    │   │   │   └── schema.json
    │   │   └── service2
    │   │       ├── Demo2Query.graphql
    │   │       └── schema.json
    │   ├── java
    │   ├── kotlin
    │   │   └── com
    │   │       └── demo
    │   │           ├── GraphqlApplication.kt
    │   │           ├── config
    │   │           │   ├── ApolloClientConfig.kt
    │   │           │   └── GraphqlProperties.kt
    │   │           └── service
    │   │               └── GraphqlApi.kt
    │   └── resources
    │       └── application.yml
    └── test
        ├── java
        ├── kotlin
        │   └── com
        │       └── demo
        │           └── XqxGraphqlApplicationTests.kt
        └── resources

build.gradle.kts

import org.jetbrains.kotlin.gradle.tasks.KotlinCompile

plugins {
  id("com.xqx.java-conventions")
	kotlin("jvm") version "1.6.21"
	kotlin("plugin.spring") version "1.6.21"
	id("com.apollographql.apollo3").version("3.5.0")
}

dependencies {
	implementation("org.springframework.boot:spring-boot-starter")
	api("org.jetbrains.kotlin:kotlin-reflect")
	api("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
	api("org.jetbrains.kotlinx:kotlinx-coroutines-jdk8")
	api("com.apollographql.apollo3:apollo-runtime:3.5.0")
	testImplementation("org.springframework.boot:spring-boot-starter-test")
}

apollo {

  // 如果一个客户端需要调用不同的graphql端点时可以配置多个服务(这个多服务配置不是必须的)
	generateKotlinModels.set(false)
 	// graphql端点一
	service("service1") {
		srcDir("src/main/graphql/service1")
		packageName.set("com.demo.graphql.service1")
	}

  // graphql端点一
	service("service2") {
		srcDir("src/main/graphql/service1")
		packageName.set("com.demo.graphql.service1")
	}
}

ApolloClientConfig.kt

/**
 *  graphql 客户端配置
 */
@Configuration
class ApolloClientConfig(@Autowired val graphqlProperties: GraphqlProperties) {


    @Bean
    fun service1ApolloClient(): ApolloClient {
        val apolloClient = ApolloClient.Builder()
            .serverUrl("https://your.domain1/graphql/endpoint")
            .build()

        return apolloClient
    }

    @Bean
    fun service2ApolloClient(): ApolloClient {
        val apolloClient = ApolloClient.Builder()
            .serverUrl("https://your.domain2/graphql/endpoint")
            .build()
        return apolloClient
    }
}

GraphqlApi.kt

/**
 *  调用接口
 */
class GraphqlApi(@Autowired val service1ApolloClient: ApolloClient, 
                 @Autowired val service2ApolloClient: ApolloClient) {


    fun fetchService1() {
    	// 使用service1ApolloClient调用
      service1ApolloClient...
    }

    @Bean
    fun fetchService2() {
        // 使用service2ApolloClient调用
      try {
        val response = service2ApolloClient.query(query).execute()
      } catch(exception: ApolloException) {
        // handle exception here
      }
    }
}
二、下载schema文件

方式一:使用gradle插件下载

# 端点一
./gradlew downloadApolloSchema \
  --endpoint="https://your.domain/graphql/endpoint" \
  --schema="src/main/graphql/service1/schema.graphqls"
# 端点二
  ./gradlew downloadApolloSchema \
  --endpoint="https://your.domain/graphql/endpoint" \
  --schema="src/main/graphql/service1/schema.graphqls"

方式二:使用apollo-js工具下载

npm install -g apollp 
npm install -g graphql
# 端点一
apollo schema:download --endpoint=http://server1/graphql schema.json
# 端点二
apollo schema:download --endpoint=http://server2/graphql schema.json
三、自动生成代码

gradle插件定义了generateApolloSources任务,通过运行generateApolloSources任务会自动生成代码到srcDir下。运行项目build的时候会自动运行generateApolloSources任务。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Apollo-Kotlin一个Kotlin 开发者提供的用于与 GraphQL 服务进行交互的库。根据引用,在 ApolloClientConfig.kt 文件定义了两个 ApolloClient 实例,分别对应两个不同的 GraphQL 服务端点。这些实例可以用于向服务端发送请求和获取响应的数据。 另外,根据引用,在 GraphqlApi.kt 文件,我们可以看到两个 ApolloClient 实例的注入。这些实例可以在 fetchService1() 和 fetchService2() 方法使用,用于调用相应的 GraphQL 服务端点。fetchService2() 方法还包含了异常处理的代码,以便在发生异常时进行处理。 综上所述,Apollo-Kotlin一个用于与 GraphQL 服务进行交互的库,它提供了方便的 API 用于发送请求和获取响应的数据。通过定义 ApolloClient 实例,并将其注入到相关的类,我们可以轻松地使用 Apollo-Kotlin 进行 GraphQL 开发。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Spring bootapollo-kotlin基本使用(一个客户端使用多个graphql端点)](https://blog.csdn.net/fggdgh/article/details/128089362)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [Kotlin进阶指南 - Parcelable序列化](https://blog.csdn.net/qq_20451879/article/details/126250953)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值