目录
1.背景
使用hutool工具包中的httpUtil发送一个很常见的http post请求,
在单元测试的时候正常,但是整合到业务代码中报错:
cn.hutool.core.io.IORuntimeException: SSLException: Received fatal alert: internal_error
执行的核心代码:
/**
* 方法:执行同步
*/
private String send(String jsonParam) {
// 公共参数
long timestamp = System.currentTimeMillis() / 1000;
String sign = createSign(timestamp, appId, appSecret);
String url = host + "/download_center/push?appid=" + appId + "×tamp=" + timestamp + "&sign=" + sign;
HttpRequest request = HttpUtil.createPost(url);
request.setConnectionTimeout(5 * 1000);
request.setReadTimeout(30 * 1000);
request.body(jsonParam);
log.info("请求url:{}", url);
log.info("请求参数:{}", jsonParam);
String body = request.execute().body();
log.info("请求响应:{}", body);
return body;
}
报错截图如下:
这个问题之前遇到过,大致原因是;ssl/tsl协议版本不一致导致的;
但是这次最主要的不同是单元测试可以,业务代码中就不行,查看了使用的jdk版本等信息,
都是一样的
.......
在网上找了很久的解决方案,有的说更换jdk版本到1.8,可我的已经是1.8了...
最后,算了..实在找不到具体的原因,我就没有使用hutool同的http工具类,
而是自己封装了一个基于apache的http client,问题得到了解决
一直都很喜欢使用hutool的工具包,这次有点认人失望,或许是自己的技术不到位,还不能很好的使用吧!
2.解决方案
自己封装了一个基于apache的http client
执行的核心代码:
/**
* 方法:执行同步
*/
private String send2(String jsonParam) {
// 公共参数
long timestamp = System.currentTimeMillis() / 1000;
String sign = createSign(timestamp, appId, appSecret);
String url = host + "/download_center/push?appid=" + appId + "×tamp=" + timestamp + "&sign=" + sign;
log.info("请求url:{}", url);
log.info("请求参数:{}", jsonParam);
String