Heim >Java >javaLernprogramm >So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

王林
王林nach vorne
2023-05-12 11:55:201012Durchsuche

Einführung

Retrofit ist ein typsicheres HTTP-Client-Tool, das für Android und Java geeignet ist. Es ist bereits auf Github 39k+Stern. Sein größtes Merkmal ist, dass es das Initiieren von HTTP-Anfragen über die Schnittstelle unterstützt, ähnlich wie wir Feign zum Aufrufen der Microservice-Schnittstelle verwenden. AndroidJava且类型安全的HTTP客户端工具,在Github上已经有39k+Star。其最大的特性的是支持通过接口的方式发起HTTP请求,类似于我们用Feign调用微服务接口的那种方式。

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

SpringBoot是使用最广泛的Java开发框架,但是Retrofit官方并没有提供专门的Starter。于是有位老哥就开发了retrofit-spring-boot-starter,它实现了Retrofit与SpringBoot框架的快速整合,并且支持了诸多功能增强,极大简化开发。今天我们将使用这个第三方Starter来操作Retrofit。

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

使用

在SpringBoot中使用Retrofit是非常简单的,下面我们就来体验下。

依赖集成

有了第三方Starter的支持,集成Retrofit仅需一步,添加如下依赖即可。

<!--Retrofit依赖-->
<dependency>
    <groupId>com.github.lianjiatech</groupId>
    <artifactId>retrofit-spring-boot-starter</artifactId>
    <version>2.2.18</version>
</dependency>

基本使用

下面以调用mall-tiny-swagger中的接口为例,我们来体验下Retrofit的基本使用。

首先我们准备一个服务来方便远程调用,使用的是之前的mall-tiny-swagger这个Demo,打开Swagger看下,里面有一个登录接口和需要登录认证的商品品牌CRUD接口,

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

我们先来调用下登录接口试试,在application.yml中配置好mall-tiny-swagger的服务地址;

remote:
  baseUrl: http://localhost:8088/

再通过@RetrofitClient声明一个Retrofit客户端,由于登录接口是通过POST表单形式调用的,这里使用到了@POST@FormUrlEncoded注解;

/**
 * 定义Http接口,用于调用远程的UmsAdmin服务
 * Created by macro on 2022/1/19.
 */
@RetrofitClient(baseUrl = "${remote.baseUrl}")
public interface UmsAdminApi {
    @FormUrlEncoded
    @POST("admin/login")
    CommonResult<LoginInfo> login(@Field("username") String username, @Field("password") String password);
}

如果你不太明白这些注解是干嘛的,看下下面的表基本就懂了,更具体的话可以参考Retrofit官方文档;

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

接下来在Controller中注入UmsAdminApi,然后进行调用即可;

/**
 * Retrofit测试接口
 * Created by macro on 2022/1/19.
 */
@Api(tags = "RetrofitController", description = "Retrofit测试接口")
@RestController
@RequestMapping("/retrofit")
public class RetrofitController {
    @Autowired
    private UmsAdminApi umsAdminApi;
    @Autowired
    private TokenHolder tokenHolder;
    @ApiOperation(value = "调用远程登录接口获取token")
    @PostMapping(value = "/admin/login")
    public CommonResult<LoginInfo> login(@RequestParam String username, @RequestParam String password) {
        CommonResult<LoginInfo> result = umsAdminApi.login(username, password);
        LoginInfo loginInfo = result.getData();
        if (result.getData() != null) {
            tokenHolder.putToken(loginInfo.getTokenHead() + " " + loginInfo.getToken());
        }
        return result;
    }
}

为方便后续调用需要登录认证的接口,我创建了TokenHolder这个类,把token存储到了Session中;

/**
 * 登录token存储(在Session中)
 * Created by macro on 2022/1/19.
 */
@Component
public class TokenHolder {
    /**
     * 添加token
     */
    public void putToken(String token) {
        RequestAttributes ra = RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = ((ServletRequestAttributes) ra).getRequest();
        request.getSession().setAttribute("token", token);
    }
    /**
     * 获取token
     */
    public String getToken() {
        RequestAttributes ra = RequestContextHolder.getRequestAttributes();
        HttpServletRequest request = ((ServletRequestAttributes) ra).getRequest();
        Object token = request.getSession().getAttribute("token");
        if(token!=null){
            return (String) token;
        }
        return null;
    }
}

接下来通过Swagger进行测试,调用接口就可以获取到远程服务返回的token了,访问地址:http://localhost:8086/swagger-ui/

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

注解式拦截器

商品品牌管理接口,需要添加登录认证头才可以正常访问,我们可以使用Retrofit中的注解式拦截器来实现。

首先创建一个注解式拦截器TokenInterceptor继承BasePathMatchInterceptor,然后在doIntercept方法中给请求添加Authorization头;

/**
 * 给请求添加登录Token头的拦截器
 * Created by macro on 2022/1/19.
 */
@Component
public class TokenInterceptor extends BasePathMatchInterceptor {
    @Autowired
    private TokenHolder tokenHolder;
    @Override
    protected Response doIntercept(Chain chain) throws IOException {
        Request request = chain.request();
        if (tokenHolder.getToken() != null) {
            request = request.newBuilder()
                    .header("Authorization", tokenHolder.getToken())
                    .build();
        }
        return chain.proceed(request);
    }
}

创建调用品牌管理接口的客户端PmsBrandApi,使用@Intercept注解配置拦截器和拦截路径;

/**
 * 定义Http接口,用于调用远程的PmsBrand服务
 * Created by macro on 2022/1/19.
 */
@RetrofitClient(baseUrl = "${remote.baseUrl}")
@Intercept(handler = TokenInterceptor.class, include = "/brand/**")
public interface PmsBrandApi {
    @GET("brand/list")
    CommonResult<CommonPage<PmsBrand>> list(@Query("pageNum") Integer pageNum, @Query("pageSize") Integer pageSize);
    @GET("brand/{id}")
    CommonResult<PmsBrand> detail(@Path("id") Long id);
    @POST("brand/create")
    CommonResult create(@Body PmsBrand pmsBrand);
    @POST("brand/update/{id}")
    CommonResult update(@Path("id") Long id, @Body PmsBrand pmsBrand);
    @GET("brand/delete/{id}")
    CommonResult delete(@Path("id") Long id);
}

再在Controller中注入PmsBrandApi实例,并添加方法调用远程服务即可;

/**
 * Retrofit测试接口
 * Created by macro on 2022/1/19.
 */
@Api(tags = "RetrofitController", description = "Retrofit测试接口")
@RestController
@RequestMapping("/retrofit")
public class RetrofitController {
    @Autowired
    private PmsBrandApi pmsBrandApi;
    @ApiOperation("调用远程接口分页查询品牌列表")
    @GetMapping(value = "/brand/list")
    public CommonResult<CommonPage<PmsBrand>> listBrand(@RequestParam(value = "pageNum", defaultValue = "1")
                                                        @ApiParam("页码") Integer pageNum,
                                                        @RequestParam(value = "pageSize", defaultValue = "3")
                                                        @ApiParam("每页数量") Integer pageSize) {
        return pmsBrandApi.list(pageNum, pageSize);
    }
    @ApiOperation("调用远程接口获取指定id的品牌详情")
    @GetMapping(value = "/brand/{id}")
    public CommonResult<PmsBrand> brand(@PathVariable("id") Long id) {
        return pmsBrandApi.detail(id);
    }
    @ApiOperation("调用远程接口添加品牌")
    @PostMapping(value = "/brand/create")
    public CommonResult createBrand(@RequestBody PmsBrand pmsBrand) {
        return pmsBrandApi.create(pmsBrand);
    }
    @ApiOperation("调用远程接口更新指定id品牌信息")
    @PostMapping(value = "/brand/update/{id}")
    public CommonResult updateBrand(@PathVariable("id") Long id, @RequestBody PmsBrand pmsBrand) {
        return pmsBrandApi.update(id,pmsBrand);
    }
    @ApiOperation("调用远程接口删除指定id的品牌")
    @GetMapping(value = "/delete/{id}")
    public CommonResult deleteBrand(@PathVariable("id") Long id) {
        return  pmsBrandApi.delete(id);
    }
}

在Swagger中调用接口进行测试,发现已经可以成功调用。

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

全局拦截器

如果你想给所有请求都加个请求头的话,可以使用全局拦截器。

创建SourceInterceptor类继承BaseGlobalInterceptor接口,然后在Header中添加source请求头。

/**
 * 全局拦截器,给请求添加source头
 * Created by macro on 2022/1/19.
 */
@Component
public class SourceInterceptor extends BaseGlobalInterceptor {
    @Override
    protected Response doIntercept(Chain chain) throws IOException {
        Request request = chain.request();
        Request newReq = request.newBuilder()
                .addHeader("source", "retrofit")
                .build();
        return chain.proceed(newReq);
    }
}

配置

Retrofit的配置很多,下面我们讲讲日志打印、全局超时时间和全局请求重试这三种最常用的配置。

日志打印 默认配置下Retrofit使用basic日志策略,打印的日志非常简单;

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

我们可以将application.yml中的retrofit.global-log-strategy属性修改为body

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

SpringBoot ist das am weitesten verbreitete Java-Entwicklungsframework, Retrofit bietet jedoch offiziell keinen dedizierten Starter an. Also entwickelte ein alter Mann retrofit-spring-boot-starter, der die schnelle Integration des Retrofit- und SpringBoot-Frameworks realisierte und viele funktionale Verbesserungen unterstützte, was die Entwicklung erheblich vereinfachte. Heute werden wir diesen Drittanbieter-Starter verwenden, um Retrofit zu betreiben.

So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBootSo verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot

Mit

    Es ist sehr einfach, Retrofit in SpringBoot zu verwenden. Lassen Sie es uns unten erleben.
  • Abhängigkeitsintegration

  • Mit der Unterstützung von Starter eines Drittanbieters dauert die Integration von Retrofit nur einen Schritt, fügen Sie einfach die folgenden Abhängigkeiten hinzu.
  • retrofit:
      # 日志打印配置
      log:
        # 启用日志打印
        enable: true
        # 日志打印拦截器
        logging-interceptor: com.github.lianjiatech.retrofit.spring.boot.interceptor.DefaultLoggingInterceptor
        # 全局日志打印级别
        global-log-level: info
        # 全局日志打印策略
        global-log-strategy: body

    Grundlegende Verwendung

    Nehmen wir die Schnittstelle in mall-tiny-swagger als Beispiel, um die grundlegende Verwendung von Retrofit zu erleben.

    #🎜🎜#Zunächst bereiten wir einen Dienst vor, um Remote-Anrufe zu ermöglichen. Wir verwenden die vorherige mall-tiny-swagger-Demo und werfen einen Blick darauf Schnittstelle und Anforderungen. Melden Sie sich bei der CRUD-Schnittstelle der zertifizierten Produktmarke an, #🎜🎜##🎜🎜#SpringBoot中So verwenden Sie das HTTP-Client-Tool Retrofit#🎜🎜##🎜🎜# Versuchen wir zunächst, die Anmeldeschnittstelle aufzurufen und mall-tiny-swagger in <code>application.yml zu konfigurieren s Serviceadresse; #🎜🎜#
    retrofit:
      # 全局连接超时时间
      global-connect-timeout-ms: 3000
      # 全局读取超时时间
      global-read-timeout-ms: 3000
      # 全局写入超时时间
      global-write-timeout-ms: 35000
      # 全局完整调用超时时间
      global-call-timeout-ms: 0
    #🎜🎜# Dann deklarieren Sie einen Retrofit-Client über @RetrofitClient. Da die Anmeldeschnittstelle über das POST-Formular aufgerufen wird, @POST und @FormUrlEncoded verwendet Weitere Informationen finden Sie in der offiziellen Retrofit-Dokumentation /014/168386372321669.png" alt="SpringBoot So verwenden Sie das HTTP-Client-Tool Retrofit" />#🎜🎜##🎜🎜# Als nächstes fügen Sie UmsAdminApi in den Controller ein und rufen ihn dann auf; # 🎜🎜#
    retrofit:
      # 重试配置
      retry:
        # 是否启用全局重试
        enable-global-retry: true
        # 全局重试间隔时间
        global-interval-ms: 100
        # 全局最大重试次数
        global-max-retries: 2
        # 全局重试规则
        global-retry-rules:
          - response_status_not_2xx
          - occur_exception
        # 重试拦截器
        retry-interceptor: com.github.lianjiatech.retrofit.spring.boot.retry.DefaultRetryInterceptor
    #🎜🎜# ist Um nachfolgende Aufrufe von Schnittstellen zu erleichtern, die eine Anmeldeauthentifizierung erfordern, habe ich die Klasse TokenHolder erstellt und das Token in der Sitzung gespeichert , testen Sie über Swagger und rufen Sie die Schnittstelle auf, die vom Remote-Dienst zurückgegeben wurde. Zugriffsadresse: http://localhost:8086/swagger-ui/#🎜🎜##🎜🎜#So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot#🎜🎜#

    Annotation interceptor

    # 🎜🎜#Produktmarkenverwaltungsschnittstelle. Für den normalen Zugriff müssen Sie einen Login-Authentifizierungsheader hinzufügen. Dazu können wir den Annotation Interceptor in Retrofit verwenden. #🎜🎜##🎜🎜#Erstellen Sie zunächst einen Annotations-Interceptor TokenInterceptor erbt BasePathMatchInterceptor und fügen Sie dann doIntercept hinzu >Authorization-Header; #🎜🎜#rrreee#🎜🎜#Erstellen Sie einen Client PmsBrandApi, der die Markenverwaltungsschnittstelle aufruft, und verwenden Sie die Annotation @Intercept zum Konfigurieren der Interceptor und Interception Path; #🎜🎜#rrreee#🎜🎜# Dann fügen Sie die PmsBrandApi-Instanz in den Controller ein und fügen Sie eine Methode zum Aufrufen des Remote-Dienstes hinzu; Die Schnittstelle in Swagger wurde getestet und festgestellt, dass sie erfolgreich aufgerufen werden kann. #🎜🎜##🎜🎜#So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot #🎜🎜#

    Globaler Interceptor

    #🎜🎜#Wenn Sie allen Anfragen einen Request-Header hinzufügen möchten, können Sie den globalen Interceptor verwenden. #🎜🎜##🎜🎜#Erstellen Sie die Klasse SourceInterceptor, um die Schnittstelle BaseGlobalInterceptor zu erben, und fügen Sie dann den Anforderungsheader source im Header hinzu. #🎜🎜#rrreee

    Konfiguration

    #🎜🎜#Retrofit hat viele Konfigurationen Im Folgenden werden wir über die drei am häufigsten verwendeten Konfigurationen sprechen: Protokolldruck, globales Timeout und globale Anforderungswiederholung. #🎜🎜#
    #🎜🎜#Protokolldruck In der Standardkonfiguration verwendet Retrofit die grundlegende Protokollstrategie und die gedruckten Protokolle sind sehr einfach; img src="https ://img.php.cn/upload/article/000/465/014/168386372413173.png" alt="So verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot" />#🎜🎜##🎜 🎜#Wir können retrofit.global-log-strategy-Eigenschaft in code>application.yml wird in body geändert, um das vollständigste Protokoll zu drucken; #🎜🎜#rrreee#🎜🎜 #Nach der Änderung der Protokolldruckstrategie sind die Protokollinformationen umfassender; #🎜🎜##🎜🎜## 🎜🎜##🎜🎜#KEINE: Protokolle nicht drucken; #🎜🎜##🎜🎜##🎜🎜##🎜🎜#BASIC: Nur Protokollanforderungsdatensätze drucken; #🎜🎜 #
  • HEADERS:打印日志请求记录、请求和响应头信息;

  • BODY:打印日志请求记录、请求和响应头信息、请求和响应体信息。

全局超时时间

有时候我们需要修改一下Retrofit的请求超时时间,可以通过如下配置实现。

retrofit:
  # 全局连接超时时间
  global-connect-timeout-ms: 3000
  # 全局读取超时时间
  global-read-timeout-ms: 3000
  # 全局写入超时时间
  global-write-timeout-ms: 35000
  # 全局完整调用超时时间
  global-call-timeout-ms: 0

全局请求重试

retrofit-spring-boot-starter支持请求重试,可以通过如下配置实现。

retrofit:
  # 重试配置
  retry:
    # 是否启用全局重试
    enable-global-retry: true
    # 全局重试间隔时间
    global-interval-ms: 100
    # 全局最大重试次数
    global-max-retries: 2
    # 全局重试规则
    global-retry-rules:
      - response_status_not_2xx
      - occur_exception
    # 重试拦截器
    retry-interceptor: com.github.lianjiatech.retrofit.spring.boot.retry.DefaultRetryInterceptor

重试规则global-retry-rules支持如下三种配置。

  • RESPONSE_STATUS_NOT_2XX:响应状态码不是2xx时执行重试;

  • OCCUR_IO_EXCEPTION:发生IO异常时执行重试;

  • OCCUR_EXCEPTION:发生任意异常时执行重试。

Das obige ist der detaillierte Inhalt vonSo verwenden Sie das HTTP-Client-Tool Retrofit in SpringBoot. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen