热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

一个极简的Http请求client推荐,一行搞玩外部请求

OKHttpUtil在Java的世界中,Http客户端之前一直是Apache家的HttpClient占据主导,但是由于此包较为庞大,AP




OKHttpUtil

在Java的世界中,Http客户端之前一直是Apache家的HttpClient占据主导,但是由于此包较为庞大,API又比较难用,因此并不使用很多场景。而新兴的OkHttp、Jodd-http固然好用,但是面对一些场景时,学习成本还是有一些的。很多时候,我们想追求轻量级的Http客户端,并且追求简单易用。而OKHttp
是一套处理 HTTP 网络请求的依赖库,由 Square 公司设计研发并开源,目前可以在 Java 和 Kotlin 中使用。对于 Android App
来说,OkHttp 现在几乎已经占据了所有的网络请求操作,对于服务器端请求外部接口也是必备的选择 。针对OKHttp
OkHttpUtil做了一层封装,使Http请求变得无比简单。


OKHttpUtil 功能
  • 根据URL自动判断是请求HTTP还是HTTPS,不需要单独写多余的代码。
  • 默认情况下COOKIE自动记录,比如可以实现模拟登录,即第一次访问登录URL后后续请求就是登录状态。
  • 自动识别304跳转并二次请求
  • 支持代理配置
  • 支持referer配置
  • 支持User-Agent配置
  • 自动识别并解压Gzip格式返回内容
  • 支持springboot 配置文件
  • 极简的封装调用

OKHttpUtil使用

maven引入


<dependency>
<groupId>io.github.admin4jgroupId>
<artifactId>httpartifactId>
<version>0.4.0version>
dependency>

最新版查询 https://search.maven.org/artifact/io.github.admin4j/http


GET

最简单的使用莫过于用HttpUtil工具类快速请求某个接口&#xff1a;

Response response &#61; HttpUtil.get("https://github.com/search", Pair.of("q", "okhttp"));
System.out.println("response &#61; " &#43; response);

POST

一行代码即可搞定&#xff0c;当然Post请求也很简单&#xff1a;

# JSON 格式的body
Response post &#61; HttpUtil.post("https://oapi.dingtalk.com/robot/send?access_token&#61;27f5954ab60ea8b2e431ae9101b1289c138e85aa6eb6e3940c35ee13ff8b6335", "{\"msgtype\": \"text\",\"text\": {\"content\":\"【反馈提醒】我就是我, 是不一样的烟火\"}}");
System.out.println("post &#61; " &#43; post);

# form 请求
Map formParams &#61; new HashMap<>(16);
formParams.put("username", "admin");
formParams.put("password", "admin123");
Response response &#61; HttpUtil.postForm("http://192.168.1.13:9100/auth/login",
formParams
);
System.out.println("response &#61; " &#43; response);

返回格式为JSON的 可以使用 HttpJsonUtil 自动返回JsonObject

JSONObject object&#61;HttpJsonUtil.get("https://github.com/search",
Pair.of("q","http"),
Pair.of("username","agonie201218"));
System.out.println("object &#61; "&#43;object);

文件上传

File file&#61;new File("C:\\Users\\andanyang\\Downloads\\Sql.txt");
Map<String, Object> formParams&#61;new HashMap<>();
formParams.put("key","test");
formParams.put("file",file);
formParams.put("token","WXyUseb-D4sCum-EvTIDYL-mEehwDtrSBg-Zca7t:qgOcR2gUoKmxt-VnsNb657Oatzo&#61;:eyJzY29wZSI6InpoYW56aGkiLCJkZWFkbGluZSI6MTY2NTMwNzUxNH0&#61;");
Response response&#61;HttpUtil.upload("https://upload.qiniup.com/",formParams);
System.out.println(response);

下载文件

HttpUtil.down("https://gitee.com/admin4j/common-http","path/");

HttpRequest 链式请求


# get
Response response&#61;HttpRequest.get("https://search.gitee.com/?skin&#61;rec&type&#61;repository")
.queryMap("q","admin4j")
.header(HttpHeaderKey.USER_AGENT,"admin4j")
.execute();
System.out.println("response &#61; "&#43;response);
# post form
Response response&#61;HttpRequest.get("http://192.168.1.13:9100/auth/login")
.queryMap("q","admin4j")
.header(HttpHeaderKey.USER_AGENT,"admin4j")
.form("username","admin")
.form("password","admin123")
.execute();
System.out.println("response &#61; "&#43;response);

post form 日志

16:49:14.092[main]DEBUG io.github.admin4j.http.core.HttpLogger- -->GET http://192.168.1.13:9100/auth/login?q&#61;admin4j http/1.1
16:49:14.094[main]DEBUG io.github.admin4j.http.core.HttpLogger-User-Agent:admin4j
16:49:14.094[main]DEBUG io.github.admin4j.http.core.HttpLogger-Host:192.168.1.13:9100
16:49:14.094[main]DEBUG io.github.admin4j.http.core.HttpLogger-Connection:Keep-Alive
16:49:14.094[main]DEBUG io.github.admin4j.http.core.HttpLogger-Accept-Encoding:gzip
16:49:14.094[main]DEBUG io.github.admin4j.http.core.HttpLogger- -->END GET
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-<--200OK http://192.168.1.13:9100/auth/login?q&#61;admin4j (575ms)
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-transfer-encoding:chunked
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-Vary:Origin
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-Vary:Access-Control-Request-Method
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-Vary:Access-Control-Request-Headers
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-Vary:Origin
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-Vary:Access-Control-Request-Method
16:49:14.670[main]DEBUG io.github.admin4j.http.core.HttpLogger-Vary:Access-Control-Request-Headers
16:49:14.671[main]DEBUG io.github.admin4j.http.core.HttpLogger-Content-Type:application/json;charset&#61;utf-8
16:49:14.671[main]DEBUG io.github.admin4j.http.core.HttpLogger-Date:Tue,08Nov 2022 08:49:14GMT
16:49:14.671[main]DEBUG io.github.admin4j.http.core.HttpLogger-
16:49:14.671[main]DEBUG io.github.admin4j.http.core.HttpLogger-{"code":406,"msg":"Full authentication is required to access this resource"}
16:49:14.671[main]DEBUG io.github.admin4j.http.core.HttpLogger-<--END HTTP(76-byte body)
response&#61;Response{protocol&#61;http/1.1,code&#61;200,message&#61;OK,url&#61;http://192.168.1.13:9100/auth/login?q&#61;admin4j}

再 Springboot 中使用

maven引入


<dependency>
<groupId>io.github.admin4jgroupId>
<artifactId>common-http-starterartifactId>
<version>0.4.0version>
dependency>

最新版查询 io.github.admin4j:common-http-starter

spring 版可以对 OkHttp进行个性化配置
配置详见

public class HttpConfig {
/**
* 日志等级
*/

private HttpLoggingInterceptor.Level loggLevel &#61; HttpLoggingInterceptor.Level.BODY;
/**
* 读取超时时间&#xff0c;秒
*/

private long readTimeout &#61; 30;
/**
* 链接超时时间
*/

private long connectTimeout &#61; 30;
private boolean followRedirects &#61; false;
/**
* 最大的连接数
*/

private int maxIdleConnections &#61; 5;
/**
* 最大的kepAlive 时间 秒
*/

private long keepAliveDuration &#61; 5;
private String userAgent &#61; "OKHTTP";
/**
* 是否支持COOKIE
*/

private boolean COOKIE &#61; false;
private ProxyConfig proxy;
&#64;Data
public static class ProxyConfig {
private Proxy.Type type &#61; Proxy.Type.HTTP;
private String host;
private Integer port &#61; 80;
private String userName;
private String password;
}
}

如何快速封装外部接口

以实体项目为例&#xff0c;封装 ebay接口

public class EbayClient extends ApiJsonClient {
/**
* 店铺配置
*
* &#64;param storeId
*/

public EbayClient(Long storeId) {
//TODO 获取店铺相关配置
Map<String, String> config &#61; new HashMap<>();
basePath &#61; "https://api.ebay.com";
defaultHeaderMap.put("Authorization", "Bearer " &#43; config.get("accessToken"));
defaultHeaderMap.put("X-EBAY-C-MARKETPLACE-ID", config.get("marketplaceId"));
}
}

EbayClient 封装ebay api请求 基础类

/**
* ebay 库存相关api
* &#64;author andanyang
*/

public class EbayInventoryClient extends EbayClient {
/**
* 店铺配置
*
* &#64;param storeId
*/

public EbayInventoryClient(Long storeId) {
super(storeId);
}
/**
* 库存列表
*
* &#64;param limit
* &#64;param offset
* &#64;return
* &#64;throws IOException
*/

public JSONObject inventoryItem(Integer limit, Integer offset) throws IOException {
Map<String, Object> queryMap &#61; new HashMap(2);
queryMap.put("limit", limit);
queryMap.put("offset", offset);
return get("/sell/inventory/v1/inventory_item", queryMap);
}
}

EbayInventoryClient 封装ebay 库存 api请求
使用

EbayInventoryClient ebayInventoryClient&#61;new EbayInventoryClient(1L);
JSONObject jsonObject&#61;ebayInventoryClient.inventoryItem(0,10);


/**
* 订单相关api
* &#64;author andanyang
*/

public class EbayOrderClient extends EbayClient {
/**
* 店铺配置
*
* &#64;param storeId
*/

public EbayOrderClient(Long storeId) {
super(storeId);
}
/**
* 订单列表
*
* &#64;param beginTime
* &#64;param endTime
* &#64;param limit
* &#64;param offset
* &#64;return
*/

public JSONObject orders(String beginTime, String endTime, int limit, int offset) {
final String path &#61; "/sell/fulfillment/v1/order";
String filter &#61; MessageFormat.format("lastmodifieddate:[{0}..{1}]", beginTime, endTime);
//
Map<String, Object> queryMap &#61; new HashMap<>(8);
queryMap.put("filter", filter);
queryMap.put("limit", limit);
queryMap.put("offset", offset);
return get("/sell/inventory/v1/inventory_item", queryMap);
}
}

库存相关的使用EbayInventoryClient,订单相关的使用EbayOrderClient,是不是很清晰


源码位置 https://github.com/admin4j/common-http







推荐阅读
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 标题: ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 本文讨论了在VMWARE5.1的虚拟服务器Windows Server 2008R2上安装oracle 10g客户端时出现的问题,并提供了解决方法。错误日志显示了异常访问违例,通过分析日志中的问题帧,找到了解决问题的线索。文章详细介绍了解决方法,帮助读者顺利安装oracle 10g客户端。 ... [详细]
  • 开发笔记:spring boot项目打成war包部署到服务器的步骤与注意事项
    本文介绍了将spring boot项目打成war包并部署到服务器的步骤与注意事项。通过本文的学习,读者可以了解到如何将spring boot项目打包成war包,并成功地部署到服务器上。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文讨论了在Spring 3.1中,数据源未能自动连接到@Configuration类的错误原因,并提供了解决方法。作者发现了错误的原因,并在代码中手动定义了PersistenceAnnotationBeanPostProcessor。作者删除了该定义后,问题得到解决。此外,作者还指出了默认的PersistenceAnnotationBeanPostProcessor的注册方式,并提供了自定义该bean定义的方法。 ... [详细]
  • SpringBoot整合SpringSecurity+JWT实现单点登录
    SpringBoot整合SpringSecurity+JWT实现单点登录,Go语言社区,Golang程序员人脉社 ... [详细]
author-avatar
芋荌源
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有