天天看点

Spring Boot Starter注解方式发送HTTP请求

前言

这是一个解决服务端发起http请求服务的框架。 由于开发人员的使用习惯不一样,每个人都有可能写出一套不同的HTTP请求util出来,而且使用的方式各不相同,还不能复用, 在用过Feign后,Feign支持比较好的是spring cloud,在不想用spring cloud的情况下,不如自己封装一套Http请求的框架,即可解决代码混乱的问题,又能优雅的开发。

框架的基本要求

  1.注解Interface(@RestClient),能用Spring依赖注入的方式来调用

  2.支持SpringMvc的注解如(@RequestMapping和@ResponseBody等)

  3.支持动态URL和参数传入

  4.断路保护

解决思路

  1.Spring启动时,扫描@RestClient注解的Interface,生成代理的javabean

  2.使用RestTemplate来发送请求,减少框架的代码量

  3.缓存执行过程的相关方法,避免多次创建javabean,提高请求效率

  4.提供请求的过滤器

写了这些,还是上菜吧

maven注入(由于没有上传到maven仓库,所以使用的小伙伴需要自己打包上传到私服。可以想看cgcg-http-spring-boot-starter的简单测试代码)

<dependency>
    <groupId>com.cgcg</groupId>
    <artifactId>cgcg-http-spring-boot-starter</artifactId>
    <version>对应的版本号</version>
</dependency>
           

@RestClient的写法

@RestClient(url = "https://your.domain/userCenter", fallback = TestClientImpl.class) //fallback 如果抛异常了会执行这个实现类的方法,且默认60秒内不再发起调用,避免频繁抱错,可以不配置
@MappingFilter(name = RequestFilter.class) //给这个类下面的全部请求添加过滤器,处理相关数据,可以自定义,也可以不写
public interface TestClient {

    @PostMapping(value = "user")
    Map<String, Object> post(@RequestBody Map<String, Object> param,             
    @RequestParam("p1") String p1);
}
           

调用方式

@Resource
    private TestClient testClient;

    public Object result(String id) {
        HashMap<String, Object> param = new HashMap<>();
        param.put("haha", id);
        final Map<String, Object> objectMap = testClient.post(param, id);
        return objectMap;
    }
           

更详细的实现可以看Github

GitHub连接:https://github.com/ZhicongLin/cgcg-base-starter/tree/master

继续阅读