非常实用的Http应用框架,杜绝Java Http 接口对接繁琐编程

简介: UniHttp 是一个声明式的 HTTP 接口对接框架,帮助开发者快速对接第三方 HTTP 接口。通过 @HttpApi 注解定义接口,使用 @GetHttpInterface 和 @PostHttpInterface 等注解配置请求方法和参数。支持自定义代理逻辑、全局请求参数、错误处理和连接池配置,提高代码的内聚性和可读性。

UniHttp是一个声明式的HTTP接口对接框架,它能够帮助开发者以极快的方式完成对一个第三方HTTP接口的对接和使用。以下是对UniHttp的详细使用说明及示例:

一、UniHttp简介

UniHttp框架注重于如何保持高内聚和可读性高的代码情况下与快速第三方渠道接口进行对接和集成。与其说是对接的HTTP接口,不如说是对接的第三方渠道。UniHttp可支持自定义接口渠道方HttpAPI注解以及一些自定义的对接和交互行为,为此扩展了发送、响应和反序列化一个HTTP请求的各种生命周期钩子,开发者可自行去扩展实现。

二、UniHttp的使用

1. 引入依赖

首先,需要在项目的pom.xml文件中引入UniHttp的依赖:

<dependency>

   <groupId>io.github.burukeyou</groupId>

   <artifactId>uniapi-http</artifactId>

   <version>0.0.4</version>

</dependency>

2. 创建接口并标记

创建一个接口,并在接口上标记@HttpApi注解,指定请求的域名URL。然后,在方法上配置对接的接口,并使用各种@Par后缀的注解来指定请求的参数。

例如:

@HttpApi(url = "http://localhost:7001/test")

public interface TestHttpApi {

   @GetHttpInterface("/getUser")

   HttpResponse<String> getUser(@QueryPar("name") String param, @HeaderPar("userId") Integer id);

 

   @PostHttpInterface("/addUser")

   HttpResponse<String> addUser(@BodyJsonPar VideoDTO req);

}

在上述示例中,@GetHttpInterface@PostHttpInterface分别用于配置GET和POST请求。@QueryPar表示将参数值放到HTTP请求的查询参数内,@HeaderPar表示将参数值放到HTTP请求的请求头里,@BodyJsonPar表示将参数值放到HTTP请求body内,并且content-type是application/json。

3. 声明定义的HttpAPI的包扫描路径

在Spring的配置类上使用@UniAPIScan注解标记定义的@HttpAPI的包扫描路径。这样,UniHttp会自动为标记了@HttpApi接口的生成代理对象,并将其注入到Spring容器中。之后,只需要像使用Spring的其他bean一样,通过依赖注入来使用这些接口。

例如:

@UniAPIScan("com.hdx.contractor.util")

@SpringBootApplication

public class DemoApplication {

   public static void main(String[] args) {

       SpringApplication.run(DemoApplication.class, args);

   }

}

4. 依赖注入并使用

通过依赖注入的方式,将创建的接口注入到需要使用的地方,并调用其方法。

例如:

@Service

public class UserAppService {

   @Autowired

   private TestHttpApi testHttpApi;

 

   public void doSomething() {

       HttpResponse<String> response = testHttpApi.getUser("test", 1);

       // 处理响应结果

   }

}

三、UniHttp的注解说明

  1. @HttpApi:用于标记接口,指定请求的域名URL,也可指定自定义的HTTP代理逻辑等。
  2. @HttpInterface及其变种(如@GetHttpInterface、@PostHttpInterface等):用于配置一个接口的参数,包括请求方式、请求路径、请求头、请求cookie、请求查询参数等。
  3. @Par后缀的注解(如@QueryPar、@HeaderPar、@BodyJsonPar等):用于方法参数上,指定在发送请求时将参数值放到HTTP请求体的哪部分上。

四、示例详解

以下是一个完整的示例,展示了如何使用UniHttp对接一个第三方HTTP接口:

// 引入必要的依赖和注解

import com.burukeyou.uniapi.http.annotation.HttpApi;

import com.burukeyou.uniapi.http.annotation.param.*;

import com.burukeyou.uniapi.http.annotation.request.GetHttpInterface;

import com.burukeyou.uniapi.http.annotation.request.PostHttpInterface;

import com.burukeyou.uniapi.http.core.response.HttpResponse;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

import org.springframework.context.annotation.Bean;

import org.springframework.stereotype.Service;

 

// 声明HTTP接口

@HttpApi(url = "http://localhost:7001/test")

public interface TestHttpApi {

   @GetHttpInterface("/getUser")

   HttpResponse<String> getUser(@QueryPar("name") String param, @HeaderPar("userId") Integer id);

 

   @PostHttpInterface("/addUser")

   HttpResponse<String> addUser(@BodyJsonPar UserDTO req);

}

 

// 用户数据传输对象

public class UserDTO {

   private String name;

   private Integer age;

   // getter和setter方法

}

 

// Spring Boot应用主类

@SpringBootApplication

@UniAPIScan("com.example.demo.api") // 指定@HttpApi接口所在的包路径

public class DemoApplication {

   public static void main(String[] args) {

       SpringApplication.run(DemoApplication.class, args);

   }

}

 

// 服务类,用于调用HTTP接口

@Service

public class UserService {

   @Autowired

   private TestHttpApi testHttpApi;

 

   public void getUserAndAddUser() {

       // 调用GET接口

       HttpResponse<String> getUserResponse = testHttpApi.getUser("John", 123);

       System.out.println("GetUser Response: " + getUserResponse.getBody());

 

       // 准备POST请求的数据

       UserDTO userDTO = new UserDTO();

       userDTO.setName("Jane");

       userDTO.setAge(25);

 

       // 调用POST接口

       HttpResponse<String> addUserResponse = testHttpApi.addUser(userDTO);

       System.out.println("AddUser Response: " + addUserResponse.getBody());

   }

}

在上面的示例中,我们首先定义了一个TestHttpApi接口,用于对接第三方的HTTP接口。然后,在Spring Boot应用主类上使用了@UniAPIScan注解来指定@HttpApi接口所在的包路径。最后,在UserService类中通过依赖注入的方式注入了TestHttpApi接口,并调用了其方法。

通过以上步骤,就可以使用UniHttp框架快速对接和使用第三方HTTP接口了。

五、高级功能与自定义配置

1. 自定义HTTP代理逻辑

UniHttp允许开发者通过实现HttpProxy接口来自定义HTTP请求的处理逻辑。这包括在发送请求之前和接收响应之后执行自定义操作。

public class CustomHttpProxy implements HttpProxy {

   @Override

   public HttpRequestWrapper beforeSend(HttpRequestWrapper requestWrapper) {

       // 在发送请求之前修改请求,例如添加自定义请求头

       requestWrapper.addHeader("Custom-Header", "HeaderValue");

       return requestWrapper;

   }

 

   @Override

   public <T> HttpResponse<T> afterReceive(HttpResponse<T> response, HttpRequestWrapper requestWrapper) {

       // 在接收响应之后处理响应,例如记录日志或修改响应内容

       System.out.println("Received response: " + response.getBody());

       return response;

   }

}

然后,在@HttpApi注解中指定这个自定义代理:

@HttpApi(url = "http://localhost:7001/test", proxy = CustomHttpProxy.class)

public interface TestHttpApi {

   // ... 接口方法

}

2. 配置全局请求参数

有时,你可能需要在所有请求中都包含某些全局参数,例如API密钥或用户令牌。这可以通过实现GlobalRequestParamProvider接口来实现。

@Component

public class GlobalRequestParamProviderImpl implements GlobalRequestParamProvider {

   @Override

   public Map<String, Object> provideParams() {

       Map<String, Object> params = new HashMap<>();

       params.put("apiKey", "your-api-key");

       return params;

   }

}

UniHttp会自动将这个全局参数添加到所有HTTP请求中。

3. 自定义错误处理

UniHttp允许你通过实现HttpErrorHandler接口来自定义错误处理逻辑。这包括处理HTTP状态码错误和请求/响应解析错误。

@Component

public class CustomHttpErrorHandler implements HttpErrorHandler {

   @Override

   public void handleError(HttpRequestWrapper requestWrapper, Throwable throwable) {

       // 自定义错误处理逻辑,例如记录日志或抛出异常

       System.err.println("Error occurred: " + throwable.getMessage());

   }

}

4. 配置连接池和超时

UniHttp使用Apache HttpClient作为底层的HTTP客户端库,因此你可以通过配置Apache HttpClient的HttpClientBuilder来自定义连接池和超时设置。

@Bean

public CloseableHttpClient httpClient() {

   HttpClientBuilder builder = HttpClients.custom();

   // 配置连接池和超时

   builder.setMaxConnTotal(100);

   builder.setDefaultRequestConfig(RequestConfig.custom()

           .setConnectTimeout(5000)

           .setSocketTimeout(5000)

           .build());

   // ... 其他配置

   return builder.build();

}

然后,在UniHttp的配置类中指定这个CloseableHttpClient实例:

@Configuration

public class UniHttpConfig {

   @Autowired

   private CloseableHttpClient httpClient;

 

   @Bean

   public UniHttpConfigurer uniHttpConfigurer() {

       return new UniHttpConfigurer() {

           @Override

           public void configure(UniHttpProperties properties) {

               properties.setHttpClient(httpClient);

               // 其他配置

           }

       };

   }

}

六、总结

UniHttp是一个强大的HTTP接口对接框架,它提供了声明式的接口定义方式、丰富的注解支持、自定义代理逻辑、全局请求参数、自定义错误处理和连接池/超时配置等高级功能。通过UniHttp,开发者可以快速地对接和使用第三方HTTP接口,同时保持代码的高内聚和可读性。无论是简单的GET/POST请求还是复杂的自定义请求处理,UniHttp都能提供灵活且强大的支持。

相关文章
|
4天前
|
存储 人工智能 弹性计算
阿里云弹性计算_加速计算专场精华概览 | 2024云栖大会回顾
2024年9月19-21日,2024云栖大会在杭州云栖小镇举行,阿里云智能集团资深技术专家、异构计算产品技术负责人王超等多位产品、技术专家,共同带来了题为《AI Infra的前沿技术与应用实践》的专场session。本次专场重点介绍了阿里云AI Infra 产品架构与技术能力,及用户如何使用阿里云灵骏产品进行AI大模型开发、训练和应用。围绕当下大模型训练和推理的技术难点,专家们分享了如何在阿里云上实现稳定、高效、经济的大模型训练,并通过多个客户案例展示了云上大模型训练的显著优势。
|
8天前
|
存储 人工智能 调度
阿里云吴结生:高性能计算持续创新,响应数据+AI时代的多元化负载需求
在数字化转型的大潮中,每家公司都在积极探索如何利用数据驱动业务增长,而AI技术的快速发展更是加速了这一进程。
|
4天前
|
人工智能 运维 双11
2024阿里云双十一云资源购买指南(纯客观,无广)
2024年双十一,阿里云推出多项重磅优惠,特别针对新迁入云的企业和初创公司提供丰厚补贴。其中,36元一年的轻量应用服务器、1.95元/小时的16核60GB A10卡以及1元购域名等产品尤为值得关注。这些产品不仅价格亲民,还提供了丰富的功能和服务,非常适合个人开发者、学生及中小企业快速上手和部署应用。
|
13天前
|
人工智能 弹性计算 文字识别
基于阿里云文档智能和RAG快速构建企业"第二大脑"
在数字化转型的背景下,企业面临海量文档管理的挑战。传统的文档管理方式效率低下,难以满足业务需求。阿里云推出的文档智能(Document Mind)与检索增强生成(RAG)技术,通过自动化解析和智能检索,极大地提升了文档管理的效率和信息利用的价值。本文介绍了如何利用阿里云的解决方案,快速构建企业专属的“第二大脑”,助力企业在竞争中占据优势。
|
15天前
|
自然语言处理 数据可视化 前端开发
从数据提取到管理:合合信息的智能文档处理全方位解析【合合信息智能文档处理百宝箱】
合合信息的智能文档处理“百宝箱”涵盖文档解析、向量化模型、测评工具等,解决了复杂文档解析、大模型问答幻觉、文档解析效果评估、知识库搭建、多语言文档翻译等问题。通过可视化解析工具 TextIn ParseX、向量化模型 acge-embedding 和文档解析测评工具 markdown_tester,百宝箱提升了文档处理的效率和精确度,适用于多种文档格式和语言环境,助力企业实现高效的信息管理和业务支持。
3936 2
从数据提取到管理:合合信息的智能文档处理全方位解析【合合信息智能文档处理百宝箱】
|
4天前
|
算法 安全 网络安全
阿里云SSL证书双11精选,WoSign SSL国产证书优惠
2024阿里云11.11金秋云创季活动火热进行中,活动月期间(2024年11月01日至11月30日)通过折扣、叠加优惠券等多种方式,阿里云WoSign SSL证书实现优惠价格新低,DV SSL证书220元/年起,助力中小企业轻松实现HTTPS加密,保障数据传输安全。
501 3
阿里云SSL证书双11精选,WoSign SSL国产证书优惠
|
11天前
|
安全 数据建模 网络安全
2024阿里云双11,WoSign SSL证书优惠券使用攻略
2024阿里云“11.11金秋云创季”活动主会场,阿里云用户通过完成个人或企业实名认证,可以领取不同额度的满减优惠券,叠加折扣优惠。用户购买WoSign SSL证书,如何叠加才能更加优惠呢?
985 3
|
8天前
|
机器学习/深度学习 存储 人工智能
白话文讲解大模型| Attention is all you need
本文档旨在详细阐述当前主流的大模型技术架构如Transformer架构。我们将从技术概述、架构介绍到具体模型实现等多个角度进行讲解。通过本文档,我们期望为读者提供一个全面的理解,帮助大家掌握大模型的工作原理,增强与客户沟通的技术基础。本文档适合对大模型感兴趣的人员阅读。
411 17
白话文讲解大模型| Attention is all you need
|
8天前
|
算法 数据建模 网络安全
阿里云SSL证书2024双11优惠,WoSign DV证书220元/年起
2024阿里云11.11金秋云创季火热进行中,活动月期间(2024年11月01日至11月30日),阿里云SSL证书限时优惠,部分证书产品新老同享75折起;通过优惠折扣、叠加满减优惠券等多种方式,阿里云WoSign SSL证书将实现优惠价格新低,DV SSL证书220元/年起。
560 5
|
4天前
|
安全 网络安全
您有一份网络安全攻略待领取!!!
深入了解如何保护自己的云上资产,领取超酷的安全海报和定制鼠标垫,随时随地提醒你保持警惕!
697 1
您有一份网络安全攻略待领取!!!