Java调用Restful API接口的几种方式–HTTPS

栏目: Java · 发布时间: 6年前

内容简介:Java调用Restful API接口的几种方式–HTTPS

最近有一个需求,为客户提供一些Restful API接口,QA使用postman进行测试,但是postman的测试接口与 java 调用的相似但并不相同,于是想自己写一个程序去测试Restful API接口,由于使用的是HTTPS,所以还要考虑到对于HTTPS的处理。由于我也是首次使用的Java调用REST风格的接口,所以还要研究一番,自然也是查阅了一些资料。

Java调用Restful API接口的几种方式–HTTPS

分析: 这个问题与模块之间的调用不同,比如我有两个模块前端和后端,前端提供前台展示,后端提供数据支持。之前使用过Hession去把后端提供的服务注册成远程服务,在前端可以通过这种远程服务直接调到后端的接口。但这对于一个公司自己的一个项目耦合性比较高的情况下使用,没有问题。但是如果给客户注册这种远程服务,似乎不太好,耦合性太高。所以就考虑用一下方式进行处理。

一,HttpClient的

HttpClient的大家也许比较熟悉但又比较陌生,熟悉是知道他可以远程调用比如请求一个URL,然后在响应里获取到返回状态和返回信息,但是今天讲的稍微复杂一点,因为今天的主题是HTTPS,这个牵涉到证书或用户认证的问题。

确定使用的HttpClient之后,查询相关资料,发现的HttpClient的新版本与老版本不同,随然兼容老版本,但已经不提倡老版本是使用方式,很多都已经标记为过时的方法或类。今天就分别使用老版本 4.2 和最新版本 4.5.3 来写代码。

老版本4.2

需要认证

在准备证书阶段选择的是使用证书认证

  1.  com.darren.test.https.v42;
  2. import   java.io.File;
  3. import   java.io.FileInputStream;
  4. import   java.security.KeyStore;
  5. import   org.apache.http.conn.ssl.SSLSocketFactory;
  6. 公共  HTTPSCertifiedClient   扩展  HTTPSClient {
  7.      public   HTTPSCertifiedClient(){
  8.     }
  9.      @覆盖
  10.      公共 无效  prepareCertificate()   抛出  异常{
  11.          //获得密匙库
  12.         KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
  13.         FileInputStream instream =   new   FileInputStream(
  14.                   文件( “C:/Users/zhda6001/Downloads/software/xxx.keystore”  ));
  15.          //密匙库的密码
  16.         trustStore.load(instream,   “password”  .toCharArray());
  17.          //注册密匙库
  18.          this  .socketFactory =   new   SSLSocketFactory(trustStore);
  19.          //不校验域名
  20.         socketFactory.setHostnameVerifier(SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
  21.     }

跳过认证

在准备证书阶段选择的是跳过认证

  1.  com.darren.test.https.v42;
  2. import   java.security.cert.CertificateException;
  3. import   java.security.cert.X509Certificate;
  4. import   javax.net.ssl.SSLContext;
  5. import   javax.net.ssl.TrustManager;
  6. import   javax.net.ssl.X509TrustManager;
  7. import   org.apache.http.conn.ssl.SSLSocketFactory;
  8. 公共  HTTPSTrustClient   扩展  HTTPSClient {
  9.      public   HTTPSTrustClient(){
  10.     }
  11.      @覆盖
  12.      公共 无效  prepareCertificate()   抛出  异常{
  13.          //跳过证书验证
  14.         SSLContext ctx = SSLContext.getInstance( “TLS”  );
  15.         X509TrustManager tm =   new   X509TrustManager(){
  16.              @覆盖
  17.              公共 无效  checkClientTrusted(X509Certificate []链,字符串authType)   抛出  CertificateException {
  18.             }
  19.              @覆盖
  20.              公共 无效  checkServerTrusted(X509Certificate []链,字符串authType)   抛出  CertificateException {
  21.             }
  22.              @覆盖
  23.              public   X509Certificate [] getAcceptedIssuers(){
  24.                  返回 null  ;
  25.             }
  26.         };
  27.          //设置成已信任的证书
  28.         ctx.init( null  ,   new   TrustManager [] {tm},   null  );
  29.          //穿件SSL socket工厂,并且设置不检查主机名称
  30.          this  .socketFactory =   new   SSLSocketFactory(ctx,SSLSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER);
  31.     }

总结

现在发现这两个类都继承了同一个类HTTPSClient,并且HTTPSClient继承了DefaultHttpClient类,可以发现,这里使用了模板方法模式。

  1.  com.darren.test.https.v42;
  2. 导入  org.apache.http.conn.ClientConnectionManager;
  3. import   org.apache.http.conn.scheme.Scheme;
  4. import   org.apache.http.conn.scheme.SchemeRegistry;
  5. import   org.apache.http.conn.ssl.SSLSocketFactory;
  6. import   org.apache.http.impl.client.DefaultHttpClient;
  7. 公共 抽象  HTTPSClient   扩展  DefaultHttpClient {
  8.      受保护的  SSLSocketFactory socketFactory;
  9.      / **
  10.      *初始化HTTPSClient
  11.      * 
  12.      * @return返回当前实例
  13.      * @例外
  14.      * /
  15.      公共  HTTPSClient init()   抛出  异常{
  16.          这个 .prepareCertificate();
  17.          这个 .regist();
  18.          返回 这个 ;
  19.     }
  20.      / **
  21.      *准备证书验证
  22.      * 
  23.      * @例外
  24.      * /
  25.      public  abstract  void   prepareCertificate()   throws   Exception;
  26.      / **
  27.      *注册协议和端口,此方法也可以被子类重写
  28.      * /
  29.      保护 无效的  注册表(){
  30.         ClientConnectionManager ccm =   this  .getConnectionManager();
  31.         SchemeRegistry sr = ccm.getSchemeRegistry();
  32.         sr.register( new   Scheme( “https”  ,   443  ,socketFactory));
  33.     }

下边是 工具

  1.  com.darren.test.https.v42;
  2. import   java.util.ArrayList;
  3. import   java.util.List;
  4. import   java.util.Map;
  5. import   java.util.Set;
  6. 导入  org.apache.http.HttpEntity;
  7. 导入  org.apache.http.HttpResponse;
  8. import   org.apache.http.NameValuePair;
  9. import   org.apache.http.client.entity.UrlEncodedFormEntity;
  10. import   org.apache.http.client.methods.HttpGet;
  11. import   org.apache.http.client.methods.HttpPost;
  12. import   org.apache.http.client.methods.HttpRequestBase;
  13. import   org.apache.http.message.BasicNameValuePair;
  14. import   org.apache.http.util.EntityUtils;
  15. 公共  HTTPSClientUtil {
  16.      private  static  final   String DEFAULT_CHARSET =   “UTF-8”  ;
  17.      public  static   String doPost(HTTPSClient httpsClient,String url,Map <String,String> paramHeader,
  18.             Map <String,String> paramBody)   throws   Exception {
  19.          返回  doPost(httpsClient,url,paramHeader,paramBody,DEFAULT_CHARSET);
  20.     }
  21.      public  static   String doPost(HTTPSClient httpsClient,String url,Map <String,String> paramHeader,
  22.             Map <String,String> paramBody,String charset)   throws   Exception {
  23.         String result =   null  ;
  24.         HttpPost httpPost =   new   HttpPost(url);
  25.         setHeader(httpPost,paramHeader);
  26.         setBody(httpPost,paramBody,charset);
  27.         HttpResponse响应= httpsClient.execute(httpPost);
  28.          if   (response!=   null  ){
  29.             HttpEntity resEntity = response.getEntity();
  30.              if   (resEntity!=   null  ){
  31.                 结果= EntityUtils.toString(resEntity,字符集);
  32.             }
  33.         }
  34.          返回  结果;
  35.     }
  36.      public  static   String doGet(HTTPSClient httpsClient,String url,Map <String,String> paramHeader,
  37.             Map <String,String> paramBody)   throws   Exception {
  38.          返回  doGet(httpsClient,url,paramHeader,paramBody,DEFAULT_CHARSET);
  39.     }
  40.      public  static   String doGet(HTTPSClient httpsClient,String url,Map <String,String> paramHeader,
  41.             Map <String,String> paramBody,String charset)   throws   Exception {
  42.         String result =   null  ;
  43.         HttpGet httpGet =   new   HttpGet(url);
  44.         setHeader(httpGet,paramHeader);
  45.         HttpResponse响应= httpsClient.execute(httpGet);
  46.          if   (response!=   null  ){
  47.             HttpEntity resEntity = response.getEntity();
  48.              if   (resEntity!=   null  ){
  49.                 结果= EntityUtils.toString(resEntity,字符集);
  50.             }
  51.         }
  52.          返回  结果;
  53.     }
  54.      private  static  void   setHeader(HttpRequestBase request,Map <String,String> paramHeader){
  55.          //设置标题
  56.          if   (paramHeader!=   null  ){
  57.             设置<String> keySet = paramHeader.keySet();
  58.              for   (String key:keySet){
  59.                 request.addHeader(key,paramHeader.get(key));
  60.             }
  61.         }
  62.     }
  63.      private  static  void   setBody(HttpPost httpPost,Map <String,String> paramBody,String charset)   throws   Exception {
  64.          //设置参数
  65.          if   (paramBody!=   null  ){
  66.             List <NameValuePair> list =   new   ArrayList <NameValuePair>();
  67.             设置<String> keySet = paramBody.keySet();
  68.              for   (String key:keySet){
  69.                 list.add( new   BasicNameValuePair(key,paramBody.get(key)));
  70.             }
  71.              if   (list.size()>   ){
  72.                 UrlEncodedFormEntity entity =   new   UrlEncodedFormEntity(list,charset);
  73.                 httpPost.setEntity(实体);
  74.             }
  75.         }
  76.     }

然后是测试类:

  1.  com.darren.test.https.v42;
  2. import   java.util.HashMap;
  3. import   java.util.Map;
  4. 公共  HTTPSClientTest {
  5.      公共 静态 无效的  主要(字符串[]参数)   抛出  异常{
  6.         HTTPSClient httpsClient =   null  ;
  7.         httpsClient =   new   HTTPSTrustClient()。init();
  8.          // httpsClient = new HTTPSCertifiedClient()。init();
  9.         String url =   “https://1.2.6.2:8011/xxx/api/getToken”  ;
  10.          // String url =“https://1.2.6.2:8011/xxx/api/getHealth”;
  11.         Map <String,String> paramHeader =   new   HashMap <>();
  12.          //paramHeader.put(“Content-Type“,”application / json“);
  13.         paramHeader.put( “Accept”  ,   “application / xml”  );
  14.         Map <String,String> paramBody =   new   HashMap <>();
  15.         paramBody.put( “client_id”  ,   “ankur.tandon.ap@xxx.com”  );
  16.         paramBody.put( “client_secret”  ,   “P @ ssword_1”  );
  17.         String result = HTTPSClientUtil.doPost(httpsClient,url,paramHeader,paramBody);
  18.         的System.out.println(结果);
  19.     }
  20.  }

返回信息:

  1. <? xml  version “1.0”  encoding “utf-8”  ?>
  2. 令牌 jkf8RL0sw + Skkflj8RbKI5hP1bEQK8PrCuTZPpBINqMYKRMxY1kWCjmCfT191Zpp88VV1aGHW8oYNWjEYS0axpLuGAX89ejCoWNbikCc1UvfyesXHLktcJqyUFiVjevhrEQxJPHncLQYWP + Xse5oD9X8vKFKk7InNTMRzQK7YBTZ / e3U7gswM / 5cvAHFl6o9rEq9cWPXavZNohyvnXsohSzDo + BXAtXxa1xpEDLy / 8小时/ UaP4n4dlZDJJ3B8t1Xh + CRRIoMOPxf7c5wKhHtOkEOeXW + xoPQKKSx5CKWwJpPuGIIFWF / PaqWg +  JUOsVT7QGdPv8PMWJ9DwEwjTdxguDg  ==  </  令牌 >

新版本4.5.3

需要认证

  1.  com.darren.test.https.v45;
  2. import   java.io.File;
  3. import   java.io.FileInputStream;
  4. import   java.security.KeyStore;
  5. import   javax.net.ssl.SSLContext;
  6. import   org.apache.http.conn.ssl.SSLConnectionSocketFactory;
  7. import   org.apache.http.conn.ssl.TrustSelfSignedStrategy;
  8. import   org.apache.http.ssl.SSLContexts;
  9. 公共  HTTPSCertifiedClient   扩展  HTTPSClient {
  10.      public   HTTPSCertifiedClient(){
  11.     }
  12.      @覆盖
  13.      公共 无效  prepareCertificate()   抛出  异常{
  14.          //获得密匙库
  15.         KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
  16.         FileInputStream instream =   new   FileInputStream(
  17.                   文件( “C:/Users/zhda6001/Downloads/software/xxx.keystore”  ));
  18.          尝试  {
  19.              //密匙库的密码
  20.             trustStore.load(instream,   “password”  .toCharArray());
  21.         }   最后  {
  22.             instream.close();
  23.         }
  24.         SSLContext sslcontext = SSLContexts.custom()。loadTrustMaterial(trustStore,TrustSelfSignedStrategy.INSTANCE)
  25.                 。建立();
  26.          this  .connectionSocketFactory =   new   SSLConnectionSocketFactory(sslcontext);
  27.     }

跳过认证

  1.  com.darren.test.https.v45;
  2. import   java.security.cert.CertificateException;
  3. import   java.security.cert.X509Certificate;
  4. import   javax.net.ssl.SSLContext;
  5. import   javax.net.ssl.TrustManager;
  6. import   javax.net.ssl.X509TrustManager;
  7. import   org.apache.http.conn.ssl.SSLConnectionSocketFactory;
  8. 公共  HTTPSTrustClient   扩展  HTTPSClient {
  9.      public   HTTPSTrustClient(){
  10.     }
  11.      @覆盖
  12.      公共 无效  prepareCertificate()   抛出  异常{
  13.          //跳过证书验证
  14.         SSLContext ctx = SSLContext.getInstance( “TLS”  );
  15.         X509TrustManager tm =   new   X509TrustManager(){
  16.              @覆盖
  17.              公共 无效  checkClientTrusted(X509Certificate []链,字符串authType)   抛出  CertificateException {
  18.             }
  19.              @覆盖
  20.              公共 无效  checkServerTrusted(X509Certificate []链,字符串authType)   抛出  CertificateException {
  21.             }
  22.              @覆盖
  23.              public   X509Certificate [] getAcceptedIssuers(){
  24.                  返回 null  ;
  25.             }
  26.         };
  27.          //设置成已信任的证书
  28.         ctx.init( null  ,   new   TrustManager [] {tm},   null  );
  29.          this  .connectionSocketFactory =   new   SSLConnectionSocketFactory(ctx);
  30.     }

总结

  1.  com.darren.test.https.v45;
  2. import   org.apache.http.config.Registry;
  3. import   org.apache.http.config.RegistryBuilder;
  4. import   org.apache.http.conn.socket.ConnectionSocketFactory;
  5. import   org.apache.http.conn.socket.PlainConnectionSocketFactory;
  6. import   org.apache.http.impl.client.CloseableHttpClient;
  7. import   org.apache.http.impl.client.HttpClientBuilder;
  8. import   org.apache.http.impl.client.HttpClients;
  9. import   org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
  10. 公共 抽象  HTTPSClient   扩展  HttpClientBuilder {
  11.      私有的  CloseableHttpClient客户端;
  12.      受保护的  ConnectionSocketFactory connectionSocketFactory;
  13.      / **
  14.      *初始化HTTPSClient
  15.      * 
  16.      * @return返回当前实例
  17.      * @例外
  18.      * /
  19.      public   closeableHttpClient init()   抛出  Exception {
  20.          这个 .prepareCertificate();
  21.          这个 .regist();
  22.          返回 这个 .client;
  23.     }
  24.      / **
  25.      *准备证书验证
  26.      * 
  27.      * @例外
  28.      * /
  29.      public  abstract  void   prepareCertificate()   throws   Exception;
  30.      / **
  31.      *注册协议和端口,此方法也可以被子类重写
  32.      * /
  33.      保护 无效的  注册表(){
  34.          //设置协议http和https对应的处理socket链接工厂的对象
  35.         注册表<ConnectionSocketFactory> socketFactoryRegistry = RegistryBuilder。<ConnectionSocketFactory> create()
  36.                 .register( “http”  ,PlainConnectionSocketFactory.INSTANCE)
  37.                 .register( “https”  ,   this  .connectionSocketFactory)
  38.                 。建立();
  39.         PoolingHttpClientConnectionManager connManager =   new   PoolingHttpClientConnectionManager(socketFactoryRegistry);
  40.         HttpClients.custom()setConnectionManager(连接管理)。
  41.          //创建自定义的httpclient对象
  42.          这个 .client = HttpClients.custom()。setConnectionManager(connManager).build();
  43.          // CloseableHttpClient client = HttpClients.createDefault();
  44.     }

工具类:

  1.  com.darren.test.https.v45;
  2. import   java.util.ArrayList;
  3. import   java.util.List;
  4. import   java.util.Map;
  5. import   java.util.Set;
  6. 导入  org.apache.http.HttpEntity;
  7. 导入  org.apache.http.HttpResponse;
  8. import   org.apache.http.NameValuePair;
  9. import   org.apache.http.client.HttpClient;
  10. import   org.apache.http.client.entity.UrlEncodedFormEntity;
  11. import   org.apache.http.client.methods.HttpGet;
  12. import   org.apache.http.client.methods.HttpPost;
  13. import   org.apache.http.client.methods.HttpRequestBase;
  14. import   org.apache.http.message.BasicNameValuePair;
  15. import   org.apache.http.util.EntityUtils;
  16. 公共  HTTPSClientUtil {
  17.      private  static  final   String DEFAULT_CHARSET =   “UTF-8”  ;
  18.      public  static   String doPost(HttpClient httpClient,String url,Map <String,String> paramHeader,
  19.             Map <String,String> paramBody)   throws   Exception {
  20.          返回  doPost(httpClient,url,paramHeader,paramBody,DEFAULT_CHARSET);
  21.     }
  22.      public  static   String doPost(HttpClient httpClient,String url,Map <String,String> paramHeader,
  23.             Map <String,String> paramBody,String charset)   throws   Exception {
  24.         String result =   null  ;
  25.         HttpPost httpPost =   new   HttpPost(url);
  26.         setHeader(httpPost,paramHeader);
  27.         setBody(httpPost,paramBody,charset);
  28.         HttpResponse响应= httpClient.execute(httpPost);
  29.          if   (response!=   null  ){
  30.             HttpEntity resEntity = response.getEntity();
  31.              if   (resEntity!=   null  ){
  32.                 结果= EntityUtils.toString(resEntity,字符集);
  33.             }
  34.         }
  35.          返回  结果;
  36.     }
  37.      public  static   String doGet(HttpClient httpClient,String url,Map <String,String> paramHeader,
  38.             Map <String,String> paramBody)   throws   Exception {
  39.          返回  doGet(httpClient,url,paramHeader,paramBody,DEFAULT_CHARSET);
  40.     }
  41.      public  static   String doGet(HttpClient httpClient,String url,Map <String,String> paramHeader,
  42.             Map <String,String> paramBody,String charset)   throws   Exception {
  43.         String result =   null  ;
  44.         HttpGet httpGet =   new   HttpGet(url);
  45.         setHeader(httpGet,paramHeader);
  46.         HttpResponse响应= httpClient.execute(httpGet);
  47.          if   (response!=   null  ){
  48.             HttpEntity resEntity = response.getEntity();
  49.              if   (resEntity!=   null  ){
  50.                 结果= EntityUtils.toString(resEntity,字符集);
  51.             }
  52.         }
  53.          返回  结果;
  54.     }
  55.      private  static  void   setHeader(HttpRequestBase request,Map <String,String> paramHeader){
  56.          //设置标题
  57.          if   (paramHeader!=   null  ){
  58.             设置<String> keySet = paramHeader.keySet();
  59.              for   (String key:keySet){
  60.                 request.addHeader(key,paramHeader.get(key));
  61.             }
  62.         }
  63.     }
  64.      private  static  void   setBody(HttpPost httpPost,Map <String,String> paramBody,String charset)   throws   Exception {
  65.          //设置参数
  66.          if   (paramBody!=   null  ){
  67.             List <NameValuePair> list =   new   ArrayList <NameValuePair>();
  68.             设置<String> keySet = paramBody.keySet();
  69.              for   (String key:keySet){
  70.                 list.add( new   BasicNameValuePair(key,paramBody.get(key)));
  71.             }
  72.              if   (list.size()>   ){
  73.                 UrlEncodedFormEntity entity =   new   UrlEncodedFormEntity(list,charset);
  74.                 httpPost.setEntity(实体);
  75.             }
  76.         }
  77.     }

测试类:

  1.  com.darren.test.https.v45;
  2. import   java.util.HashMap;
  3. import   java.util.Map;
  4. import   org.apache.http.client.HttpClient;
  5. 公共  HTTPSClientTest {
  6.      公共 静态 无效的  主要(字符串[]参数)   抛出  异常{
  7.         HttpClient httpClient =   null  ;
  8.          // httpClient = new HTTPSTrustClient()。init();
  9.         httpClient =   new   HTTPSCertifiedClient()。init();
  10.         String url =   “https://1.2.6.2:8011/xxx/api/getToken”  ;
  11.          // String url =“https://1.2.6.2:8011/xxx/api/getHealth”;
  12.         Map <String,String> paramHeader =   new   HashMap <>();
  13.         paramHeader.put( “Accept”  ,   “application / xml”  );
  14.         Map <String,String> paramBody =   new   HashMap <>();
  15.         paramBody.put( “client_id”  ,   “ankur.tandon.ap@xxx.com”  );
  16.         paramBody.put( “client_secret”  ,   “P @ ssword_1”  );
  17.         String result = HTTPSClientUtil.doPost(httpClient,url,paramHeader,paramBody);
  18.         的System.out.println(结果);
  19.     }

结果:

  1. <? xml  version “1.0”  encoding “utf-8”  ?>
  2. 令牌 RxitF9 // 7NxwXJS2cjIjYhLtvzUNvMZxxEQtGN0u07sC9ysJeIbPqte3hCjULSkoXPEUYGUVeyI9jv7 / WikLrzxYKc3OSpaTSM0kCbCKphu0TB2Cn / nfzv9fMLueOWFBdyz + N0sEiI9K + 0Gp7920DFEncn17wUJVmC0u2jwvM5FAjQKmilwodXZ6a0Dq + D7dQDJwVcwxBvJ2ilhyIb3pr805Vppmi9atXrVAKO0ODa006wEJFOfcgyG5p70wpJ5rrBL85vfy9WCvkd1R7j6NVjhXgH2gNimHkjEJorMjdXW2gKiUsiWsELi / XPswao7 /  CTWNwTnctGK8PX2ZUB0ZfA  ==  </  令牌 >

二,HttpURLConnection类

三,春节的RestTemplate

其它方式以后补充

原文地址 http://www.bieryun.com/562.html


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

计算几何

计算几何

周培德 / 清华大学出版社 / 2011-9 / 82.00元

《计算几何--算法设计与分析(第4版)》(作者周培德)系统地介绍了计算几何中的基本概念、求解诸多问题的算法及复杂性分析,概括了求解几何问题所特有的许多思想方法、几何结构与数据结构。全书共分10章,包括:预备知识,几何查找(检索),多边形,凸壳及其应用,Voronoi图、三角剖分及其应用,交与并及其应用,多边形的获取及相关问题,几何体的划分与等分,路径与回路,几何拓扑网络设计等。 《计......一起来看看 《计算几何》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具