注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

网易杭州 QA Team

务实 专注 分享 做有态度的QA

 
 
 
 
 

日志

 
 

HttpClient 接口测试遇到的问题及解决方案  

来自葛庆阳   2015-08-01 14:23:44|  分类: 接口测试 |举报 |字号 订阅

  下载LOFTER 我的照片书  |


一、HttpClient介绍

目前HttpClient支持HTTP/1.1这个版本定义的所有Http方法:GETHEADPOSTPUTDELETETRACEOPTIONSHttpClient的官方解释如下:Http协议应该是互联网中最重要的协议。持续增长的web服务、可联网的家用电器等都在继承并拓展着Http协议,向着浏览器之外的方向发展。

虽然jdk中的java.net包中提供了一些基本的方法,通过http协议来访问网络资源,但是大多数场景下,它都不够灵活和强大。HttpClient致力于填补这个空白,它可以提供有效的、最新的、功能丰富的包来实现http客户端。

为了拓展,HttpClient即支持基本的http协议,还支持http-aware客户端程序,如web浏览器,网络服务客户端,或者用于平、拓展http协议的分布式系统。

HttpClient的定义:

是一个基于HttpCore的客户端Http传输类库
基于传统的(阻塞)IO
内容无关
      HttpClient不能做的事情:

HttpClient不是浏览器,它是一个客户端http协议传输类库。HttpClient被用来发送和接受Http消息。HttpClient不会处理http消息的内容,不会进行javascript解析,不会关心content type,如果没有明确设置,httpclient也不会对请求进行格式化、重定向url,或者其他任何和http消息传输相关的功能。

在项目中引入HttpClient,以Maven为例:

  <dependency>

        <groupId>org.apache.httpcomponents</groupId>

        <artifactId>httpclient</artifactId>

        <version>4.5</version>

   </dependency>

二、遇到的问题及解决方案

1、  缺少证书

sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target

问题的根本是:

缺少安全证书时出现的异常。

解决问题方法:

从网站https://confluence.atlassian.com/download/attachments/180292346/InstallCert.java 下载InstallCert.java程序

编译InstallCert.java,然后执行:java InstallCert hostname,比如:java InstallCert www.163.com

根据提示操作,会在当前的目录下产生一个名为“ssecacerts”的证书。

将证书拷贝到$JAVA_HOME/jre/lib/security目录下,问题便得到解决。

2、  上传excel文件

A、请求负载是文件的情形

F12,打开chrome,在上传excel文件时,请求负载如图所示:

HttpClient 接口测试遇到的问题及解决方案 - 葛庆阳 - dreamsyeah
 通过post请求上传文件用到org.apache.httpcomponentshttpmime jar包,在Maven中加入依赖:

       <dependency>

             <groupId>org.apache.httpcomponents</groupId>

             <artifactId>httpmime</artifactId>

             <version>4.5</version>

       </dependency>

实现的核心代码为:

HttpPost httpPost = new HttpPost(url);

FileBody file = new FileBody(new File(GlobalSetting.getResoucesPath()+fileName));

HttpEntity reqEntity = MultipartEntityBuilder.create()

.addPart("myfile", file)

.build();

httpPost.setEntity(reqEntity);

CloseableHttpResponse response = httpclient.execute(httpPost);

其中,fileName为“商品资料批量导入模板(女装).xlsx”。需要创建FileBody,并将其添加到由MultipartEntityBuilder创建的HttpEntity中。

B、请求负载中有字符串的情形

HttpClient 接口测试遇到的问题及解决方案 - 葛庆阳 - dreamsyeah
 

实现的核心代码为:

HttpPost httpPost = new HttpPost(url);

FileBody file = new FileBody(new File(GlobalSetting.getResoucesPath()+fileName));

StringBody id = new StringBody(PoId,Charset.forName("UTF-8"));

HttpEntity reqEntity = MultipartEntityBuilder.create()

.addPart("scheduleId", id)

.addPart("myfile", file)                   

          .build();

  httpPost.setEntity(reqEntity);

CloseableHttpResponse response = httpclient.execute(httpPost);

其中,fileName为“档期商品批量导入模板.xlsx”;PoId为“1033046”。需要创建FileBodyStringBody并将其添加到由MultipartEntityBuilder创建的HttpEntity中。

3、  POST请求不是键值对的形式

一般情况下post请求的负载中都是键值对的形式,如下图所示:

HttpClient 接口测试遇到的问题及解决方案 - 葛庆阳 - dreamsyeah
 通过JSON或者List <NameValuePair> nvps = new ArrayList <NameValuePair>()的方式实现;

以下是通过JSON实现:

JSONObject postEntityJSON= new JSONObject();

postEntityJSON.put("curSupplierAreaId","0");

postEntityJSON.put("endDate","1444924799000");

postEntityJSON.put("limit","10");

postEntityJSON.put("offset","0");

postEntityJSON.put("startDate","1410710400000");

postEntityJSON.put("status","0");

现在遇到的难题是请求不是键值对的形式,如下图所示:

HttpClient 接口测试遇到的问题及解决方案 - 葛庆阳 - dreamsyeah
 

实现的核心代码为:

HttpPost post = new HttpPost(url);

post.setHeader("Accept", "application/json");

post.setHeader("Content-Type", "application/json");

post.setEntity(new StringEntity("["+PoId+"]"));

CloseableHttpResponse response = httpclient.execute(post);

其中,PoId为“1033046”,因为之前没遇到过请求不是键值对的情形,所以不知如何实现,通过查阅官方文档后发现,直接设置post的实体即可实现。

4、  修改excel文件内容

因为建立档期需要通过excel文件上传,手动修改excel文件的内容比较麻烦,所以想通过java在程序中修改excel文件的相关内容,提高效率。

需要在maven中添加依赖,如下所示:

       <dependency>

          <groupId>org.apache.poi</groupId>

          <artifactId>poi</artifactId>

          <version>3.9</version>

       </dependency>    

       <dependency>

          <groupId>org.apache.poi</groupId>

          <artifactId>poi-ooxml</artifactId>

          <version>3.9</version>

</dependency>

其中poi针对后缀为.xlsexcel文件,poi-ooxml针对后缀为.xlsxexcel文件;

其中部分代码如下所示:

       try

      {

       FileInputStream file = new FileInputStream(new File(GlobalSetting.getResoucesPath()+excelName));          

XSSFWorkbook workbook = new XSSFWorkbook(file);         

XSSFSheet sheet = workbook.getSheetAt(0);       

int rowNum = sheet.getLastRowNum();

            XSSFRow row = sheet.getRow(0);

            int index = 0;

            for (int i = 2; i <= rowNum; i++) {

                  row = sheet.getRow(i);

                 row.getCell(3).setCellValue(list.get(index++));

            }        

FileOutputStream out = new FileOutputStream(new File(GlobalSetting.getResoucesPath()+excelName));                

workbook.write(out);

            file.close();

            out.close();

        } catch (Exception e){

         e.printStackTrace();

}

5、  压缩文件

由于商品图片是通过上传ZIP压缩文件实现的,在图片上传之前要把命名号的商品图片进行压缩,人为进行操作也很麻烦,希望通过java程序实现文件的压缩。

Java中有现存的zip压缩的API,需要import java.util.zip.*;

操作流程为:复制文件到指定目录并按照要求命名各个商品图片文件名,然后将各个商品文件集体压缩成zip包,接着删除各个商品图片文件名,降低存储空间。最后便可上传压缩的ZIP包了。



  评论这张
 
阅读(2571)| 评论(1)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016