请求第三方接口

该代码段展示了如何使用Java原生的HttpClient进行GET请求,同时处理HttpServletRequest中的Cookie信息,并在请求中添加Header。如果用户已登录,将Cookie添加到请求中,否则使用默认的HttpClient。最后,从响应中获取数据并转化为JSONArray。

原生Http

 public static JSONArray doGet(String url, String param, HttpServletRequest request) {
        HttpClient client = null;
        JSONArray jsonArray = new JSONArray();
        HttpGet get = new HttpGet(param != null ? url + "?" + param : url);

		// 设置cookie -- 方法1(接收方接收不到)
        Cookie[] cookies = request.getCookies();
        if (cookies != null) {
            boolean isLogin = false;
            String UUID = "";
            String UUID_NEW = "";
            String SSIONID = "";
            for (Cookie cookie1 : cookies) {
                if (cookie1.getName().equals("UUID") || cookie1.getName().equals("UUID_NEW")) {
                    isLogin = true;
                    if (cookie1.getName().equals("UUID")) {
                        UUID = cookie1.getValue();
                    } else if (cookie1.getName().equals("NEW")) {
                        UUID_NEW = cookie1.getValue();
                    } else if (cookie1.getName().equals("SSIONID")) {
                        SSIONID = cookie1.getValue();
                    }
                }
            }
            if (isLogin) {
                BasicCookieStore cookieStore = new BasicCookieStore();
                BasicClientCookie cookie_1 = new BasicClientCookie("UUID", EASEOK_UUID);
                BasicClientCookie cookie_2 = new BasicClientCookie("UUID_NEW", EASEOK_UUID_NEW);
                BasicClientCookie cookie_3 = new BasicClientCookie("SSIONID", JSESSIONID);
                cookie_1.setDomain("localhost");
                cookie_2.setDomain("localhost");
                cookie_3.setDomain("localhost");
                cookie_1.setPath("/");
                cookie_2.setPath("/");
                cookie_3.setPath("/");
                cookieStore.addCookie(cookie_1);
                cookieStore.addCookie(cookie_2);
                cookieStore.addCookie(cookie_3);
                client = HttpClientBuilder.create().setDefaultCookieStore(cookieStore).build();
                // 设置cookie -- 方法2
                get.setHeader("Cookie", "UUID=" + UUID + ";UUID_NEW=" + UUID_NEW + ";SSIONID=" + SSIONID);
            } else {
                client = HttpClients.createDefault();
            }
        }

        try {
            get.addHeader("content-type", "text/xml");
            HttpResponse res = client.execute(get);
            String response = EntityUtils.toString(res.getEntity());
            System.out.println(response);
            if (res.getStatusLine().getStatusCode() == HttpStatus.SC_OK && !response.equals("[]")) {
                jsonArray = JSONObject.parseArray(response);
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
        return jsonArray;
    }

//调用
JSONArray jsonArray = HttpUtil.doGet("http://192.168.2.100/platform/api/webDisk/getSettingIp", null,request);

webflux

对于高并发请求第三方接口,可以使用 HttpClient 来实现。以下是一些实践中的建议: 1. 使用连接池:在高并发环境下,创建和关闭连接会消耗大量资源和时间。使用连接池可以重复利用连接,提高性能。HttpClient 提供了连接池管理器,可以通过 PoolingHttpClientConnectionManager 类来管理连接池。 2. 设置超时时间:在请求第三方接口时,应该设置合理的超时时间。如果接口响应时间过长,应该及时中断请求,防止占用过多资源。可以通过 RequestConfig 类的 setConnectTimeout 和 setSocketTimeout 方法来设置连接和读取超时时间。 3. 并发执行请求:可以使用多线程或线程池来并发执行请求。每个线程可独立创建 HttpClient 实例,并使用独立的连接池进行请求。这样可以提高并发能力,同时注意要控制并发线程数量,避免对第三方接口造成过大的负载。 4. 考虑流量控制:高并发请求可能导致第三方接口的压力过大,可能会被服务提供方限制流量或拒绝服务。可以通过限制每秒请求的数量、使用消息队列等方式来控制流量,避免对第三方接口造成过大的压力。 5. 错误处理和重试机制:在请求第三方接口时,要考虑网络异常、超时、返回错误码等情况。可以通过捕获异常并进行重试,或者根据返回的错误码进行相应的处理。 综上所述,使用 HttpClient 可以方便地实现高并发请求第三方接口,并根据实际情况进行连接池管理、设置超时时间、并发执行请求、流量控制以及错误处理和重试等操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值