非常实用的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月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
223 6
|
4月前
|
IDE Java 编译器
java编程最基础学习
Java入门需掌握:环境搭建、基础语法、面向对象、数组集合与异常处理。通过实践编写简单程序,逐步深入学习,打牢编程基础。
283 1
|
5月前
|
SQL Java 数据库
2025 年 Java 从零基础小白到编程高手的详细学习路线攻略
2025年Java学习路线涵盖基础语法、面向对象、数据库、JavaWeb、Spring全家桶、分布式、云原生与高并发技术,结合实战项目与源码分析,助力零基础学员系统掌握Java开发技能,从入门到精通,全面提升竞争力,顺利进阶编程高手。
1002 0
|
4月前
|
安全 前端开发 Java
从反射到方法句柄:深入探索Java动态编程的终极解决方案
从反射到方法句柄,Java 动态编程不断演进。方法句柄以强类型、低开销、易优化的特性,解决反射性能差、类型弱、安全性低等问题,结合 `invokedynamic` 成为支撑 Lambda 与动态语言的终极方案。
212 0
|
4月前
|
安全 前端开发 Java
《深入理解Spring》:现代Java开发的核心框架
Spring自2003年诞生以来,已成为Java企业级开发的基石,凭借IoC、AOP、声明式编程等核心特性,极大简化了开发复杂度。本系列将深入解析Spring框架核心原理及Spring Boot、Cloud、Security等生态组件,助力开发者构建高效、可扩展的应用体系。(238字)
|
4月前
|
消息中间件 缓存 Java
Spring框架优化:提高Java应用的性能与适应性
以上方法均旨在综合考虑Java Spring 应该程序设计原则, 数据库交互, 编码实践和系统架构布局等多角度因素, 旨在达到高效稳定运转目标同时也易于未来扩展.
259 8
|
4月前
|
存储 安全 Java
《数据之美》:Java集合框架全景解析
Java集合框架是数据管理的核心工具,涵盖List、Set、Map等体系,提供丰富接口与实现类,支持高效的数据操作与算法处理。
|
4月前
|
存储 算法 安全
Java集合框架:理解类型多样性与限制
总之,在 Java 题材中正确地应对多样化与约束条件要求开发人员深入理解面向对象原则、范式编程思想以及JVM工作机理等核心知识点。通过精心设计与周密规划能够有效地利用 Java 高级特征打造出既健壮又灵活易维护系统软件产品。
146 7
|
8月前
|
Java 数据库连接 API
2025 更新必看:Java 编程基础入门级超级完整版指南
本教程为2025更新版Java编程基础入门指南,涵盖开发环境搭建(SDKMAN!管理JDK、VS Code配置)、Java 17+新特性(文本块、Switch表达式增强、Record类)、面向对象编程(接口默认方法、抽象类与模板方法)、集合框架深度应用(Stream API高级操作、并发集合)、模式匹配与密封类等。还包括学生成绩管理系统实战项目,涉及Maven构建、Lombok简化代码、JDBC数据库操作及JavaFX界面开发。同时提供JUnit测试、日志框架使用技巧及进阶学习资源推荐,助你掌握Java核心技术并迈向高级开发。
835 5
|
监控 安全 Java
Java中的多线程编程:从入门到实践####
本文将深入浅出地探讨Java多线程编程的核心概念、应用场景及实践技巧。不同于传统的摘要形式,本文将以一个简短的代码示例作为开篇,直接展示多线程的魅力,随后再详细解析其背后的原理与实现方式,旨在帮助读者快速理解并掌握Java多线程编程的基本技能。 ```java // 简单的多线程示例:创建两个线程,分别打印不同的消息 public class SimpleMultithreading { public static void main(String[] args) { Thread thread1 = new Thread(() -> System.out.prin