package com.wl.webservice;

import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.SocketException;
import java.net.SocketTimeoutException;
import java.net.URL;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate; import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.X509TrustManager; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.ricoh.rapp.ezcx.iwbservice.util.Constant;
import com.ricoh.rapp.ezcx.iwbservice.util.Utils; public class HttpsRequest {   private final Logger logger = LoggerFactory.getLogger(HttpsRequest.class); /**
* 处理https GET/POST请求
* @param requestUrl 请求地址
* @param requestMethod 请求方法
* @param requestStr 请求参数
* @return
*/
  public JSONObject httpsRequest(String requestUrl, String requestMethod, String requestStr) {
    logger.info("req---->:" + requestMethod + requestStr);
    HttpsURLConnection httpsConnection = null;
    try {
      // 创建SSLContext
      SSLContext sslContext = SSLContext.getInstance("SSL");
      TrustManager[] tm = { new TrustManager() };
      // 初始化
      sslContext.init(null, tm, new java.security.SecureRandom());       // 获取SSLSocketFactory对象
      SSLSocketFactory ssf = sslContext.getSocketFactory();
      HostnameVerifier HostnameVerifier = new HostnameVerifier() {
        @Override
        public boolean verify(String var1, SSLSession var2) {
          return true;
        }       };       URL url = new URL(requestUrl);
      httpsConnection = (HttpsURLConnection) url.openConnection();
      httpsConnection.setDoOutput(false);
      httpsConnection.setDoInput(true);
      httpsConnection.setConnectTimeout("3 * 1000");
      httpsConnection.setReadTimeout("15 * 1000");
      httpsConnection.setRequestProperty("Content-Type", "application/json;charset=UTF-8");
      httpsConnection.setRequestProperty("Charset", "UTF-8");
      httpsConnection.setRequestProperty("Authorization", "Basic aXdidXNlcjp0ZXN0MDAwMA==");
      httpsConnection.setRequestProperty("User-Agent", "Client identifier");
      httpsConnection.setRequestMethod("GET");
      /*
      * httpsConnection.setUseCaches(false);
      * httpsConnection.setRequestMethod(requestMethod);
      */
      // 设置当前实例使用的SSLSoctetFactory
      httpsConnection.setSSLSocketFactory(ssf);
      httpsConnection.setHostnameVerifier(HostnameVerifier);
      httpsConnection.connect();
      // 往服务器端写内容
      // 读取服务器端返回的内容
      InputStream inputStream = httpsConnection.getInputStream();
      if (httpsConnection.getResponseCode() != HttpURLConnection.HTTP_OK) {
        logger.error("connect ezcs service failed: " + httpsConnection.getResponseCode());
        JSONObject responseJson = new JSONObject();
        responseJson.put(ResponseKey.KEY_RESULT,
          com.ricoh.rapp.unifiedPlatform.dsdkService.constant.HttpConstant.ResultCode.ERROR_SERVER_HTTP_ERROR);
        return responseJson;
      }
      String response = Utils.convertStreamToString(inputStream, Constant.ENCODING_UTF_8);
      logger.debug("response from ezcs service: " + response);
      JSONObject responseJson = JSON.parseObject(response);
      return responseJson;
    } catch (Exception e) {
      e.printStackTrace();
      logger.debug("connect local ezcs service exception: " + e.getMessage());
      JSONObject responseJson = new JSONObject();
      if (e instanceof SocketTimeoutException || e instanceof SocketException) {
        responseJson.put(ResponseKey.KEY_RESULT,
          com.ricoh.rapp.unifiedPlatform.dsdkService.constant.HttpConstant.ResultCode.ERROR_SERVER_HTTP_ERROR);
      } else {
        responseJson.put(ResponseKey.KEY_RESULT,
          com.ricoh.rapp.unifiedPlatform.dsdkService.constant.HttpConstant.ResultCode.ERROR_INNER_ERROR);
      }
     return responseJson;
    } finally {
      if (httpsConnection != null) {
        httpsConnection.disconnect();
      }
    }
  }   class TrustManager implements X509TrustManager {     @Override
    public void checkClientTrusted(X509Certificate[] arg0, String arg1) throws CertificateException {     }       @Override
    public void checkServerTrusted(X509Certificate[] arg0, String arg1) throws CertificateException {     }     @Override
    public X509Certificate[] getAcceptedIssuers() {
      return new X509Certificate[] {};
    }   }   public static class ResponseKey {
    public static final String KEY_RESULT = "result";
    public static final String KEY_REASON = "reason";
    public static final String KEY_DATA = "data";
    public static final String KEY_EXTRA = "extra";
  } }

java的https的get请求的更多相关文章

  1. java 实现https请求

    java 实现https请求 JSSE是一个SSL和TLS的纯Java实现,通过JSSE可以很容易地编程实现对HTTPS站点的访问.但是,如果该站点的证书未经权威机构的验证,JSSE将拒绝信任该证书从 ...

  2. Java发送HTTPS请求

    前言 上篇文章介绍了 java 发送 http 请求,大家都知道发送http是不安全的 .我也是由于对接了其他企业后总结了一套发送 https的工具.大家网上找方法很多的,但是可不是你粘过来就能用啊, ...

  3. Java 发送 Https 请求工具类 (兼容http)

    依赖 jsoup-1.11.3.jar <dependency> <groupId>org.jsoup</groupId> <artifactId>js ...

  4. java 模拟浏览器发送post请求

    java使用URLConnection发送post请求 /** * 向指定 URL 发送POST方法的请求 * * @param url * 发送请求的 URL * @param param * 请求 ...

  5. HTTPS那些事 用java实现HTTPS工作原理

    HTTPS那些事 用java实现HTTPS工作原理 博客分类: java历险   今天被问到关于https原理的问题,结果由于知识掌握不牢靠,停留于表面,很多细节都无法回答清楚,于是决定把https的 ...

  6. Java访问HTTPS时证书验证问题

    为了尽可能避免安全问题,公司的很多系统服务都逐步https化,虽然开始过程会遇到各种问题,但趋势不改.最完美的https应用是能实现双向认证,客户端用私钥签名用服务端公钥加密,服务端用私钥签名客户端都 ...

  7. java实现https免证书认证

    java实现https免证书认证   解决方法: 1.下载两个包,httpclient-4.2.jar和httpcore-4.2.jar,复制以下代码就可使用. 2.调用类代码: String htt ...

  8. 【SpringBoot】 Java中如何封装Http请求,以及JSON多层嵌套解析

    前言 本文中的内容其实严格来说不算springboot里面的特性,属于JAVA基础,只是我在项目中遇到了,特归纳总结一下. HTTP请求封装 目前JAVA对于HTTP封装主要有三种方式: 1. JAV ...

  9. 如何设置Fiddler来拦截Java代码发送的HTTP请求,进行各种问题排查

    我们使用Java的RestTemplate或者Apache的HTTPClient编程的时候,经常遇到需要跟踪Java 代码发送的HTTP请求明细的情况.和javascript代码在浏览器里发送请求可以 ...

随机推荐

  1. 【职业规划】该如何选择职业方向?性能?自动化?测开?,学习选择python、java?看完你会感谢我的~

    前言 随着近两年来互联网行业的飞速发展,互联网技术的从业人员也越来越多. 近两年来技术岗位中测试和前端工程师变成了程序员中最好招的岗位. 测试行业卷也越来越厉害了. 也正是因为如此,我们要把自己的路越 ...

  2. 多个UID为0的用户如何实现root用户的免密

    文章目录 创建用户 创建用户密码 免密脚本 当前主机用户不是root 当前主机用户是root,远程主机多个用户uid为0 利用shell脚本实现远程主机uid为0的用户只有root一个 多个UID=0 ...

  3. php异步:在php中使用fsockopen curl实现类似异步处理的功能方法

    PHP从主流来看,是一门面向过程的语言,它的最大缺点就是无法实现多线程管理,其程序的执行都是从头到尾,按照逻辑一路执行下来,不可能出现分支,这一点是限制php在主流程序语言中往更高级的语言发展的原因之 ...

  4. Dubbo源码剖析五之服务本地缓存

    Dubbo调用者需要通过注册中心(例如:ZK)注册信息,获取提供者.但是如果频繁从ZK获取信息肯定会存在单点故障问题,所以Dubbo提供了将提供者信息缓存在本地的方法. Dubbo在订阅注册中心的回调 ...

  5. 图文并茂详解 NAT 协议!

    什么是 NAT 协议 我们的计算机要想访问互联网上的信息,就需要一个地址,而且这个地址是大家(其他主机)所认可的,是公共的,这个地址也叫做公有 IP 地址. 与之相对的,除了公有 IP 地址外,还有私 ...

  6. web开发 小方法1-禁止横向滚动

    最近学了学做了个公司的网站  总结了一些小方法 比如取消横向滚动条并禁止的横向滚动 这样就可以吧超出的切掉让网页更和谐 在body 标签 body{ text-align: center; overf ...

  7. MyBatisPlus根据ID修改对应的值,其他属性不变.如何实现?

    1.基本操作 // 修改订单的状态为已发货和已支付 Order order = new Order(); order.setSend(1); // 已发货 order.setPay(1); // 已支 ...

  8. 数据分析实际案例之:pandas在泰坦尼特号乘客数据中的使用

    目录 简介 泰坦尼特号乘客数据 使用pandas对数据进行分析 引入依赖包 读取和分析数据 图形化表示和矩阵转换 简介 1912年4月15日,号称永不沉没的泰坦尼克号因为和冰山相撞沉没了.因为没有足够 ...

  9. 2022李宏毅作业hw1—新冠阳性人员数量预测。

    ​ 事前  : kaggle地址:ML2021Spring-hw1 | Kaggle 我的git地址: https://github.com/xiaolilaoli/lihongyi2022homew ...

  10. 不需要高价购买BI工具,掌握这个Excel插件就能碾压大数据

    ​曾几何时,EXCEL在数据界可谓是独树一帜,引领风骚,在职场中无人不知,无人不晓.但是随着大数据的出现,EXCEL便风光不再,江河日下,一度被其他大数据工具挤到了后面,逐渐被边缘化了.而我是一个EX ...