解决jdk1.6不支持TLS1.2协议的问题(javax.net.ssl.SSLHandshakeException: Received fatal alert: handshake_failure)
jdk1.6忽略证书验证和用户验证
·
解决方法:找到域名对应的ip,然后用http:ip/xx/xx的方式访问,这样可以忽略证书验证和用户验证
具体使用方法如下:
<%@page contentType="text/html;charset=utf-8" language="java"%>
<%@page import="java.util.*,java.text.*,java.sql.*,java.rmi.RemoteException" %>
<%@page import="java.net.HttpURLConnection"%>
<%@page import="java.net.URL"%>
<%@ page import="org.apache.http.impl.client.CloseableHttpClient" %>
<%@ page import="org.apache.http.impl.client.HttpClients" %>
<%@ page import="org.apache.http.client.methods.CloseableHttpResponse" %>
<%@ page import="org.apache.http.client.utils.URIBuilder" %>
<%@ page import="org.apache.http.client.methods.HttpGet" %>
<%@ page import="org.apache.http.HttpEntity" %>
<%@ page import="org.apache.http.util.EntityUtils" %>
<%@ page import="org.apache.http.client.ClientProtocolException" %>
<%@ page import="java.net.URISyntaxException" %>
<%@ page import="java.io.IOException" %>
<%!
public static String getData() {
// 获取连接客户端工具
CloseableHttpClient httpClient = HttpClients.createDefault();
String entityStr = null;
CloseableHttpResponse response = null;
try {
/*
* 由于GET请求的参数都是拼装在URL地址后方,所以我们要构建一个URL,带参数
*/
URIBuilder uriBuilder = new URIBuilder("http://ip/user/getUserInfo");
/** 第一种添加参数的形式 */
/*uriBuilder.addParameter("name", "root");
uriBuilder.addParameter("password", "123456");*/
/** 第二种添加参数的形式 */
// List<NameValuePair> list = new LinkedList<>();
// BasicNameValuePair param1 = new BasicNameValuePair("name", "root");
// BasicNameValuePair param2 = new BasicNameValuePair("password", "123456");
// list.add(param1);
// list.add(param2);
// uriBuilder.setParameters(list);
// 根据带参数的URI对象构建GET请求对象
HttpGet httpGet = new HttpGet(uriBuilder.build());
/*
* 添加请求头信息
*/
// 浏览器表示
httpGet.addHeader("User-Agent", "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.7.6)");
// 传输的类型
httpGet.addHeader("Content-Type", "application/x-www-form-urlencoded");
httpGet.addHeader("Authorization", "Bearer a86ee4b9-b87e-4259-87af-d69bb6a17b20");
// 执行请求
response = httpClient.execute(httpGet);
// 获得响应的实体对象
HttpEntity entity = response.getEntity();
// 使用Apache提供的工具类进行转换成字符串
entityStr = EntityUtils.toString(entity, "UTF-8");
} catch (ClientProtocolException e) {
System.err.println("Http协议出现问题");
e.printStackTrace();
} catch (Exception e1) {
System.err.println("解析错误");
e1.printStackTrace();
}finally {
// 释放连接
if (null != response) {
try {
response.close();
httpClient.close();
} catch (IOException e) {
System.err.println("释放连接出错");
e.printStackTrace();
}
}
}
// 打印响应内容
// 打印响应内容
System.out.println(entityStr);
return entityStr;
}
%>
<%
String data = getData();
System.out.println("data="+data);
out.println("result="+data);
%>
一开始用ajax请求,直接报跨域的错误,然后用java调,在xxx.java文件的main函数中发送http请求,能正常返回数据,放在jsp里面就不行了,返回的数据为null,也不报任何错。后面用hutool的httpUtil调成功了,但是只支持jdk1.8。然后继续想办法用忽略证书验证和用户验证的方法,用到的包都是jdk1.8的。把https改成http绕过http,结果还是域名会强转成443。然后又尝试了用Nginx配置反向代理,把页面和ajax请求放在同一个域,本地的Nginx是调成功了。但是用公司的部署在公网的Nginx会报云防护如下的错:
一时半会儿没找到为什么。最后面就直接找到域名对应的ip,然后用http去访问,可以了!!!
那个激动啊!!!
更多推荐
已为社区贡献1条内容
所有评论(0)