解决方法:找到域名对应的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去访问,可以了!!!

那个激动啊!!!

Logo

鸿蒙生态一站式服务平台。

更多推荐