非常实用的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都能提供灵活且强大的支持。

相关文章
|
3月前
|
IDE Java 编译器
java编程最基础学习
Java入门需掌握:环境搭建、基础语法、面向对象、数组集合与异常处理。通过实践编写简单程序,逐步深入学习,打牢编程基础。
263 1
|
3月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
198 6
|
3月前
|
人工智能 算法 Java
Java与AI驱动区块链:构建智能合约与去中心化AI应用
区块链技术和人工智能的融合正在开创去中心化智能应用的新纪元。本文深入探讨如何使用Java构建AI驱动的区块链应用,涵盖智能合约开发、去中心化AI模型训练与推理、数据隐私保护以及通证经济激励等核心主题。我们将完整展示从区块链基础集成、智能合约编写、AI模型上链到去中心化应用(DApp)开发的全流程,为构建下一代可信、透明的智能去中心化系统提供完整技术方案。
340 3
|
3月前
|
安全 前端开发 Java
从反射到方法句柄:深入探索Java动态编程的终极解决方案
从反射到方法句柄,Java 动态编程不断演进。方法句柄以强类型、低开销、易优化的特性,解决反射性能差、类型弱、安全性低等问题,结合 `invokedynamic` 成为支撑 Lambda 与动态语言的终极方案。
195 0
|
3月前
|
消息中间件 缓存 Java
Spring框架优化:提高Java应用的性能与适应性
以上方法均旨在综合考虑Java Spring 应该程序设计原则, 数据库交互, 编码实践和系统架构布局等多角度因素, 旨在达到高效稳定运转目标同时也易于未来扩展.
182 8
|
4月前
|
算法 安全 Java
除了类,Java中的接口和方法也可以使用泛型吗?
除了类,Java中的接口和方法也可以使用泛型吗?
183 11
|
3月前
|
Java Go 开发工具
【Java】(9)抽象类、接口、内部的运用与作用分析,枚举类型的使用
抽象类必须使用abstract修饰符来修饰,抽象方法也必须使用abstract修饰符来修饰,抽象方法不能有方法体。抽象类不能被实例化,无法使用new关键字来调用抽象类的构造器创建抽象类的实例。抽象类可以包含成员变量、方法(普通方法和抽象方法都可以)、构造器、初始化块、内部类(接 口、枚举)5种成分。抽象类的构造器不能用于创建实例,主要是用于被其子类调用。抽象类中不一定包含抽象方法,但是有抽象方法的类必定是抽象类abstract static不能同时修饰一个方法。
250 1
|
4月前
|
人工智能 Java API
Java与大模型集成实战:构建智能Java应用的新范式
随着大型语言模型(LLM)的API化,将其强大的自然语言处理能力集成到现有Java应用中已成为提升应用智能水平的关键路径。本文旨在为Java开发者提供一份实用的集成指南。我们将深入探讨如何使用Spring Boot 3框架,通过HTTP客户端与OpenAI GPT(或兼容API)进行高效、安全的交互。内容涵盖项目依赖配置、异步非阻塞的API调用、请求与响应的结构化处理、异常管理以及一些面向生产环境的最佳实践,并附带完整的代码示例,助您快速将AI能力融入Java生态。
774 12
|
Web App开发 前端开发 Java
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html><head><meta http-equiv="Cont
线程的状态有:new、runnable、running、waiting、timed_waiting、blocked、dead 当执行new Thread(Runnabler)后,新创建出来的线程处于new状态,这种线程不可能执行 当执行thread.start()后,线程处于runnable状态,这种情况下只要得到CPU,就可以开始执行了。
873 0

热门文章

最新文章