Retrofit:使用【Retrofit】优雅地对接第三方接口_lianjiatech-程序员宅基地

技术标签: java  各大实战问题分析  

在这里插入图片描述

一、前言

  • 在实际开发当中,我们常常会对接一些第三方的接口来获取我们想要的数据。过去以往的对接技术比较繁琐,且不优雅。今天就来介绍一下如何使用:Retrofit 优雅地对接第三方接口。
  • 今天介绍的这款:Retrofit 是由 github作者: LianjiaTech 发布的一个与 SpringBoot 整合的项目,使用起来比较简单,功能丰富,代码也比较优雅。
  • 项目地址:github: https://github.com/LianjiaTech/retrofit-spring-boot-starter

二、Retrofit 的介绍

  • Retrofit 是适用于 AndroidJava 且类型安全的 HTTP 客户端,其最大的特性的是支持通过接口的方式发起 HTTP 请求。而 Spring-Boot 是使用最广泛的 Java 开发框架,但是 Retrofit 官方没有支持与 Spring-Boot 框架快速整合,因此 LianjiaTech:github 作者他们开发了 Retrofit-Spring-Boot-Starter
  • retrofit-spring-boot-starter 实现了 RetrofitSpring-Boot 框架快速整合,并且支持了诸多功能增强,极大简化开发。

三、HTTP请求相关注解

  • HTTP 请求相关注解,详细信息可参考官方文档:retrofit retrofit:官方文档,以下是一个简单的说明。
  • 请求方式:@GET @HEAD @POST @PUT @DELETE @OPTIONS @HTTP
  • 请求头:@Header @HeaderMap @Headers
  • 查询参数:@Query @QueryMap @QueryName
  • 路径参数:@Path
  • 形式编码参数:@Field @FieldMap @FormUrlEncoded
  • 请求体:@Body
  • 上传文件:@Multipart @Part @PartMap
  • 网址参数:@Url

四、具体使用

  • 这里我就直接演示 Retrofit 是如何具体使用的,详细的具体参数可参考上方 github 项目,里面有具体的介绍。

  • 由于我们这个项目会对接大量的第三方接口,所以我们都会归类起来针对一个具体的功能建一个 interface,然后去对接第三方不同的接口,最终哪里用到直接注入对应接口即可,通过Service调用具体方法嵌入到业务中。

  • 接口的基本请求 IP直接用这个自定义注解,里面用这个 baseUrl 即可

在这里插入图片描述

  • baseUrl 我们直接写在配置里面会好一些,这样可以正对不同环境进行变换,而不是直接写死

在这里插入图片描述

  • 关于上图中 @Sign 自定义注解的作用
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
@Documented
@InterceptMark
public @interface Sign {
    

    String cookie() default "";

    /**
     * 拦截器匹配路径
     *
     * @return
     */
    String[] include() default {
    "/**"};

    /**
     * 拦截器排除匹配,排除指定路径拦截
     *
     * @return
     */
    String[] exclude() default {
    };

    /**
     * 处理该注解的拦截器类
     * 优先从spring容器获取对应的Bean,如果获取不到,则使用反射创建一个!
     * 
     * 注意:BasePathMatchInterceptor:这个抽象方法在github项目中有具体的源码,可以直接搜索查看和使用
     * @return
     */
    Class<? extends BasePathMatchInterceptor> handler() default SignInterceptor.class;
}

1、添加

  • 这里对接是第三方的一个添加接口,其实就是跟我们平时在 Controller 层写接口一样的。添加的话我们就用:@POST,里面的参数就是第三的 URL,然后就是定义出参入参参数。
  • 至于如何快速地获取第三方接口接口生成实体类,可以看我这篇文章:IDEA:插件系列:GsonFormat插件的具体使用与介绍
  • 由于添加入参一般就是 JSON 数据,然后我们按照上面介绍的 HTTP 具体注解介绍来对号入座加上就可以了。这个 @Header 也是必填参数,具体可以根据对接的第三方接口参数结构来写。

在这里插入图片描述

2、删除

在这里插入图片描述

3、修改

在这里插入图片描述

4、查询

  • 这个查询是不带分页的

在这里插入图片描述

  • 带分页的

在这里插入图片描述

5、具体测试

  • 那么我们在接口中写好这些方法后,如何知道是否写的真确呢,那么这时我们就需要写一个测试类用Postman测试一下,确保接口能返回我们想要的数据就好。
  • 下面只是举例,具体可以根据自己的项目来编写测试类
@Slf4j
@RestController
@RequiredArgsConstructor(onConstructor = @__(@Lazy))
@RequestMapping("docking/vpn")
public class DockingVpnController {
    

    private final DockingVpnService dockingVpnService;

    private final UserFeign userFeign;

    @PostMapping("/add")
    public R<DockingAddVpnGatewayDto> addVpnGatewayInfo(@RequestBody @Valid AddVpnGatewayParam param) {
    
        //占时使用,测试需手动写入UserId
        Long userId = 0L;
        UserInfoEntity userInfoEntity = userFeign.getById(userId).getData();
        String keystoneToken = getTokenByUserId(userInfoEntity.getId(), userInfoEntity.getType());
        AddVpnGatewayParam.VpnserviceDTO vpnService = param.getVpnservice();
        DockingAddVpnGatewayDto vpnGatewayDto = dockingVpnService.addVpnGatewayInfo(param, keystoneToken);
        DockingAddVpnGatewayDto.VpnserviceDTO vpnServiceDTO = vpnGatewayDto.getVpnservice();
        vpnServiceDTO
                .setName(vpnService.getName())
                .setRouterId(vpnService.getRouterId());
        return R.success(vpnGatewayDto);

    }

Retrofit 与 Okhttp 区别

总结

  • 总而言之,这个整合后的框架时非常好用的,使用起来不管是新手还是老手都非常容易上手。对接起来也是十分的方便,真的十分感谢整合的原作者。
  • 各位有这个需求的小伙伴,也可以去用一下,真香警告!
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Mango_Bin/article/details/122473228

智能推荐

DNS分离解析-程序员宅基地

文章浏览阅读114次。DNS分离解析包: bind #域名服务包, bind-chroot #提供虚拟根支持服务: named主配置文件: /etc/named.conf #设置本机负责解析的域名地址库文件: /var/named/ #主机名与IP地址的对应关系运行时的虚拟根环境:/var/named/chroot/ #牢笼政策分离解析概述(视图解析)当收到客户机的DNS查询..._dns分离解析匹配客户端来源的字段

第一章-第七题( 有人认为,“中文编程”, 是解决中国程序员编程效率一个秘密武器,请问它是一个 “银弹” 么? )--By 侯伟婷...-程序员宅基地

文章浏览阅读208次。  首先,“银弹”在百度百科中的解释是银色的子弹,我们更熟知的“银弹”一词,应该是在《人月神话》中提到的。银弹原本应该是指某种策略、技术或者技巧可以极大地提高程序员的生产力【1】。此题目中关于中文编程是否是一个“银弹”的讨论,我所持的是否定的态度,我不认为中文编程会是一项提高中国程序员编程效率的一个秘密武器,相反,我还认为他会比现在的英文编程来说降低工作效率,造成很大的工作上的困难。..._存在一种策略,技术技巧可以极大的提高程序员的生产力。

模拟用户操作 京东抢购 华为mate40 Pro、支付的js脚本_京东抢华为脚本-程序员宅基地

文章浏览阅读5.4k次,点赞2次,收藏29次。1 登录 https://item.jd.com/10024680695127.html2 打开开发者模式,插入如下代码,count=1nIntervId=0 stop=0 var goDate function start(){ if (stop==1){ clearInterval(nIntervId);//停止监控 return } if (Date.now() < goDate){ return _京东抢华为脚本

php eayswoole node axios crypto-js 实现大文件分片上传复盘_cryptojs 处理文件过大-程序员宅基地

文章浏览阅读740次。1)前端侧 :前端上传文件,根据分片大小,自动计算出整个文件的分片数量,以及分片二进制文件,以及整个文件的md5值,以及分片文件md5值,传与后端,后端处理完后,根据上传分片的进度以及后端返回状态,判断整个文件是否传输完毕,完毕后,前端展示完成进度。2)后端PHP侧:后端接收前端传过来的数据,包括文件名,文件md5,分片信息,然后将分片文件信息存储到redis 有序集合中,其中key为整个文件的md5 ,待所有分片文件都上传完后,根据顺序,然后将文件整合存储,然后完成整个文件分片上传逻辑。_cryptojs 处理文件过大

VScode 编译器配置IDE环境(C/C++/Go)_vscode 配置 在ide上编译运行-程序员宅基地

文章浏览阅读4.5k次,点赞4次,收藏29次。VScode 编译器配置IDE环境(C/C++/Go)摘要VS Code 下载安装下载安装简单使用WindowsLinuxIDE 环境配置C/C++C/C++ 编译器安装及配置简单使用 VS Code 终端进行编译和运行方式使用code runner插件:Go总结摘要对于 VS Code 的使用,我本人感觉这个编译器还是很好用的,而且目前能够支持在 Windows、Linux、MacOs 上流畅运行,并且官方已经提供了 X86、ARM等主流架构版本,还很容易通过安装插件就能过实现基于 SSH 的远程代_vscode 配置 在ide上编译运行

oracle use_ntl详细解释_oracle中use_nl提示-程序员宅基地

文章浏览阅读1k次。1./*+ use_nl(t2,t) */提示走nest Loop,但是没有提示t2还是t为驱动表2./*+ ordered user_nl(t2,t) */提示走 Nest Loop,order提示的是from 后面的第一个表为驱动表.3./*+ leading(t2) use_nl(t) */直接提示t2为驱动表。结论:use_NL不能让优化器确定谁是驱动表谁是被驱动表。use_nl(t,t2)也没有指出哪个是驱动表,这时候我们就需要使用Ordered ,_oracle中use_nl提示

随便推点

CRM项目-模块一-程序员宅基地

文章浏览阅读1.3k次,点赞3次,收藏4次。模块一:CRM-用户管理1.CRM基本概念CRM 系统即客户关系管理系统, 顾名思义就是管理公司与客户之间的关系。 是一种以"客户关系一对一理论"为基础,旨在改善企业与客户之间关系的新型管理机制。客户关系管理的定义是:企业为提高核心竞争力,利用相应的信息技术以及互联网技术来协调企业与顾客间在销售、营销和服务上的交互,从而提升其管理方式,向客户提供创新式的个性化的客户交互和服务的过程。 其最终目标是吸引新客户、保留老客户以及将已有客户转为忠实客户,增加公司市场份额。CRM 的实施目标就是通过全面提_crm项目

arm 32linux,C语言实现文件pcm转换wav,提供代码实验用PCM音频文件_mp3 to wav c语言-程序员宅基地

文章浏览阅读199次,点赞2次,收藏3次。linux系统C语言音频文件pcm转换wav,提供实验用PCM音频文件_mp3 to wav c语言

JVM详解-栈&堆_jvm 堆栈-程序员宅基地

文章浏览阅读2.7k次,点赞3次,收藏15次。栈&堆栈栈结构JVM中的栈Java中的栈1、栈里面存放什么2、栈运行原理堆堆(Heap)新生区老年区永久区出现OOMVM options参数栈栈结构栈是一种数据结构。程序=数据结构+算法栈:先进后出,后进先出队列:先进先出(FIFO)Q:为什么main()方法先执行后结束A:先进栈,最后出JVM中的栈Oracle关于栈和栈帧提供了如下描述:每个JVM线程拥有一个私有的 Java虚拟机栈,创建线程的同时栈也被创建。一个JVM栈由许多帧组成,称之为"栈帧"。JVM中的栈和C等常见语言_jvm 堆栈

5、Nacos 、Sentinel、Seata下载与安装_sentinel下载安装-程序员宅基地

文章浏览阅读1.8k次,点赞2次,收藏10次。1、官网:https://nacos.io/zh-cn/index.html2、 下载3、解压安装双击startup.cmdjava.io.IOException: java.lang.IllegalArgumentException: db.num is null如果出现以上错误,需要指令启动:单机模式启动 window版本 startup.cmd -m standalone4、访问登录http://localhost:8848/nacos/index.html#/._sentinel下载安装

linux ssh远程登录退出,ssh登陆小技巧-用SSH 退出符切换 SSH 会话-程序员宅基地

文章浏览阅读1.7k次。用SSH 退出符切换 SSH 会话这个技巧非常实用。尤其是远程登陆到一台主机A,然后从A 登陆到B,如果希望在A 上做一些操作,还得再开一个终端,很是麻烦。当你使用ssh从本机登录到远程主机时,你可能希望切换到本地做一些操作,然后再重新回到远程主机。这个时候,你不需要中断 ssh连接,只需要按照如下步骤操作即可:当你已经登录到了远程主机时,你可能想要回到本地主机进行一些操作,然后又继续回到远程主机..._linux中ssh远程登录后如何回到原来主机

[渝粤教育] 四川农业大学 计算机网络 参考 资料_调制的信号是单一频率的载波信号吗-程序员宅基地

文章浏览阅读796次。教育-计算机网络-章节资料考试资料-四川农业大学【】随堂测验1、【单选题】以下哪一项不属于物联网的实现基础A、可穿戴设备B、RFIDC、APPD、蓝牙参考资料【 】2、【单选题】以下哪一项不是解决网络安全问题的因素A、 安全技术B、法律法规C、道德自律D、多种应用参考资料【 】电路交换随堂测验1、【单选题】以下哪一项不是电路交换的特征A、按需建立点对点信道B、数据无需携带地址信息C、点对点信道独占经过的物理链路带宽D、两两终端之间可以同时通信参考资料_调制的信号是单一频率的载波信号吗

推荐文章

热门文章

相关标签