范文健康探索娱乐情感热点
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

还用HttpUtil?用这款优雅的HTTP客户端工具吧,跟SpringBoot绝配

  我们平时开发项目时,就算是单体应用,也免不了要调用一下其他服务提供的接口。此时就会用到HTTP客户端工具,之前一直使用的是Hutool中的HttpUtil,虽然容易上手,但用起来颇为麻烦!最近发现一款更好用的HTTP客户端工具  Retrofit  ,你只需声明接口就可发起HTTP请求,无需进行连接、结果解析之类的重复操作,用起来够优雅,推荐给大家!  简介
  Retrofit是适用于Android 和Java 且类型安全的HTTP客户端工具,在Github上已经有39k+ Star。其最大的特性的是支持通过接口的方式发起HTTP请求,类似于我们用Feign调用微服务接口的那种方式。
  SpringBoot是使用最广泛的Java开发框架,但是Retrofit官方并没有提供专门的Starter。于是有位老哥就开发了retrofit-spring-boot-starter ,它实现了Retrofit与SpringBoot框架的快速整合,并且支持了诸多功能增强,极大简化开发。今天我们将使用这个第三方Starter来操作Retrofit。
  使用
  在SpringBoot中使用Retrofit是非常简单的,下面我们就来体验下。   依赖集成
  有了第三方Starter的支持,集成Retrofit仅需一步,添加如下依赖即可。       com.github.lianjiatech     retrofit-spring-boot-starter     2.2.18  基本使用
  下面以调用  mall-tiny-swagger  中的接口为例,我们来体验下Retrofit的基本使用。  首先我们准备一个服务来方便远程调用,使用的是之前的 mall-tiny-swagger 这个Demo,打开Swagger看下,里面有一个登录接口和需要登录认证的商品品牌CRUD接口,项目地址:https://github.com/macrozheng/mall-learning/tree/master/mall-tiny-swagger
  我们先来调用下登录接口试试,在 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 login(@Field("username") String username, @Field("password") String password); } 如果你不太明白这些注解是干嘛的,看下下面的表基本就懂了,更具体的话可以参考Retrofit官方文档;
  接下来在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 login(@RequestParam String username, @RequestParam String password) {         CommonResult 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/
  注解式拦截器
  商品品牌管理接口,需要添加登录认证头才可以正常访问,我们可以使用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> list(@Query("pageNum") Integer pageNum, @Query("pageSize") Integer pageSize);      @GET("brand/{id}")     CommonResult 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> 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 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中调用接口进行测试,发现已经可以成功调用。
  全局拦截器
  如果你想给所有请求都加个请求头的话,可以使用全局拦截器。
  创建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 日志策略,打印的日志非常简单;
  我们可以将 application.yml 中的retrofit.global-log-strategy 属性修改为body 来打印最全日志; retrofit:   # 日志打印配置   log:     # 启用日志打印     enable: true     # 日志打印拦截器     logging-interceptor: com.github.lianjiatech.retrofit.spring.boot.interceptor.DefaultLoggingInterceptor     # 全局日志打印级别     global-log-level: info     # 全局日志打印策略     global-log-strategy: body 修改日志打印策略后,日志信息更全面了;
  Retrofit支持四种日志打印策略;  NONE:不打印日志;  BASIC:只打印日志请求记录;  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:发生任意异常时执行重试。  总结
  今天体验了一把Retrofit,对比使用HttpUtil,确实优雅不少!通过接口发起HTTP请求已不再是Feign的专属,通过Retrofit我们在单体应用中照样可以使用这种方式。当然retrofit-spring-boot-starter 提供的功能远不止于此,它还能支持微服务间的调用和熔断降级,感兴趣的朋友可以研究下!

新一代泡面神器,iPadmini6渲染图再曝光,全面屏A14处理器苹果的小屏产品似乎都不安常理更新,每次大家的爆料漫天飞,认为即将发布的时候,苹果的发布会总会让你失望。iPhoneSE如此,iPadmini也是如此。从去年开始iPadmini6的iPadmini6来袭,加持M1芯片可能性大,iPadAir4有望迎来降价笔歌科技独家报道消息越发肯定,苹果秋季发布会肯定会带来一款平板电脑,外界推测是iPad9或者iPadmini6,但现在各方面显示来的是iPadmini6可能性更大,同时iPadAi从4999元跌至3599元,3200万8GB运存,顶级IP68防水旗舰重回低价国内的很多高端旗舰在国外非常难以销售,因为不支持IP68防水,例如今年下半年手机行业中的两款重磅旗舰小米MIX4以及vivoiQOO8Pro,它们的国行版本起步价都已经是4999元GoPro新一代旗舰运动相机Hero1011。15发布GoPro新一代旗舰运动相机Hero10将于11月15日正式发布。目前,该产品的详细参数已再次曝光。相机将配备前后双屏,内置最新的GP2芯片,性能预计是上一代的两倍。该相机将配备一MTK驱动总是安装失败,怎么刷机?mtk的驱动好像是用fastboot连接电脑时才能安装的先把开发者选项里的OEM解锁开关打开然后调到fastboot模式,用命令解锁,刷入文件fastbootflashingunliPhone1312屏幕刘海对比确实小不少还有一天多,最新的iPhone13就要发布了,很多用户都已经等不及了。而近日,国内手机贴膜配件厂商晒出了iPhone13和iPhone12系列的屏幕对比,其中不难看出,iPhone全新电视盒子!覆盖全网影视,无需担心失效!追剧看片不用愁大家好,我是裤老师。今天再次给大家分享两款主流的电视盒子,电视盒子软件好多失效比较快,过不了多久就割韭菜了,不用担心,裤老师会不断地更新好的盒子软件。2号币影视TV版支持平台TV安文石BOOXMira护眼显示器重度墨水屏用户的使用感受和技巧分享本文转自知乎用户newhill对BOOXMira的评测,已征得作者授权发布。0。背景介绍本人是墨水屏发烧友,出于阅读书籍资料的护眼的考虑,购入了不少墨水屏设备,第一台墨水屏设备要追电动车过马路,怎么走,要下车推行?法律明确了,车主一看就懂请您在阅读前,先点击上面的关注。感谢您的支持,我们将为您带来更多有价值的内容。近日,汕头交警在街头执法的新闻上了热搜。其中有多名车主在横穿马路时,被交警拦截了下来。其中有位车上绑着realme新机官宣9月22日发布realme就正式官宣了真我GTNeo2新机,将于9月22日举办主题为以强大,回敬热爱的新品发布会,成为今天当之无愧的主角。不得不说,真我GTNeo2新机的热度确实颇高,从曝光到官中国高科技产业的真正龙头10大芯片半导体企业全球IEE国际芯片导线技术会议上,专家组最终达成一致,将石墨烯定义为下一个新型半导体材料,将碳基芯片定义为下一个芯片时代的主流。那么什么是碳基芯片呢?众所周知,目前主流芯片是硅基芯
背刺小米12,IQOO9系列能否后来者居上?价格或是关键相信小米12系列的售价公布,既让很多用户大吃一惊,也使得其他厂商松了一口气。小米12起售价3699元,小米12Pro起售价4699元,尽管对比上一代产品首发价均便宜了300元,但考华为nova系列发展史,你用过哪款华为nova系列的手机?比如nova6说到华为nova系列,nova定位是中端,主打是高颜值青春,当然了拍照也是非常强大的,nova系列的拍照吸引了很多女性,销量更是很好,虽然处理器方面没有p系列系列Mate系列那么好最高性价比的手机对标红米11Pro8256,1799元,120枕三星屏幕,67w快冲,侧边指纹,6纳米联发科920,5160毫安电池,sgs护眼认证,jbl立体声,侧边指纹,204克,8。34mm,6MIUI13更新了这些内容!1月底第一批内测机型推送,新机优先刚刚小米12系列发布会终于带来了大家期待的MIUI13系统,这次系统主要更新了什么内容呢!下面我们通过以下信息了解一下它的核心部分,目前部分机型的内测用户以及可以到小米社区申请MI大疆车载团队人员已接近1000人张兴旺中国证券报中证网中证网讯(记者张兴旺)日前,在大疆车载体验交流活动上,大疆车载市场负责人谢阗地表示,大疆车载很多业务正在推进,作为一家一级供应商,大疆车载正在发挥自己的长处,华为可惜了,如果麒麟芯片正常发布,华为有望直接封神一直以来,芯片都是我国科技方面发展的短板,不管是手机电脑还是电视汽车,芯片都需要其他国家和企业供应,其中,手机要求的芯片精度和难度是最高的。而在手机领域当中,高通则有着十分重要的地中国芯逆风翻盘?新型芯片构架悄然崛起,中科院华为已提前布局就在我们为中国芯片产业担忧时,中国工程院院士倪光南却表示现如今在中国芯面前其实还有一条康庄大道。不仅能让中国摆脱外国的架构垄断制约,还能让中国科技企业将芯片的发展主动权牢牢掌握在自12。29基金操作分享白酒芯片新能源车等板块分析今天市场整体表现较差,沪指也是勉强在3600点附近震荡,创业板盘中失守3300点,整数关口的支撑力已经没了。盘面上,军工钢铁等板块涨幅居前,白酒,食品饮料等板块跌幅居前。对于后市的数字货币与科技企业股价大跌背后有什么新趋势?这些热点值得关注你好,这里是科技前哨。今天科技前哨和你一起看看风投和业内人士如何看待近期数字货币价格大跌科技股行情波动,了解一下哈佛商业评论为什么说最近美国工人工资涨太快都是媒体的幻觉。1。数字货小米12小屏旗舰xiaomi12小屏旗舰11。28超大底镜头骁龙85000万像素1。22pmUFS3。1LPDDR52。44um(4in1)WIFI6增强版F1。9超大光圈NFC红外遥控OIS光学元旦年货节电视又降价,部分2500元档机型松动,比双11力度更大再过两天就是2022年了,感慨时间飞逝的同时,又来了个各个品牌不会放过的活动节点元旦年货节。大家都知道节前快递会停运,所以年货节也是春节前最后一次电商的活动。这次跨年,迎来的年货节