完成一个接口调用其实就是完成了一次http请求,所以你必须要清楚一个http请求的组成。

一次完整的请求包含:请求+响应。

一、HttpRequest请求对象

要调用一个接口,首先要准备的是一个请求对象,上一篇代码实现中创建post对象实际就是准备一个HttpRequest类型的对象:

  1. //1.创建post对象,以post方式提交接口请求
  2. HttpPost httpPost = new HttpPost(restUrl);

为什么我们可以把httpPost对象称为请求对象?HttpPost与HttpRequest是什么关系呢,下图给出了二者之间的关系:

由此图可以看出,HttpPost是HttpRequest的实现类,因此它一个HttpRequest类型的请求对象。

HttpPost对象常用api整理:

1) 构造函数:HttpPost httpPost = new HttpPost(url),创建一个请求对象,请求类型为post,url作为参数,设置接口请求地址。

2) httpPost.setURI(URI uri),此中方式也可以设置接口请求的地址。

3) httpPost.addHeader(String name,String value),给一个请求对象添加请求头信息,传达给服务器某些信息,后面会给大家简单的介绍下请求头这个概念。

4) httpPost.setEntity(HttpEntity httpEntity),设置请求提交数据,比如接口参数。

5) ...

HttpGet类型也属于HttpRequest类型,处理get类型的接口调用要用到HttpGet对象,本文不对HttpGet做过多介绍。有相关问题欢迎讨论区发问。

二、HttpResponse响应对象

一个请求只要服务器响应了就会有一个HttpResponse对象产生,此响应对象中会有响应头,状态码,响应数据报文等。

上一个篇章中我们用HttpClient框架技术处理接口调用时,响应对象用的是CloseableHttpResponse类型,这个类型是HttpResponse的子接口,二者的继承关系如下:

CloseableHttpResponse类型对象httpResponse的常用api整理:

1) httpResponse.getFirstHeader(String name):从响应对象里获取指定名字的首个响应头(响应头,传达给客户端的信息)。

2) httpResponse.getStatusLine().getStatusCode():从响应对象中获取状态码,(200:成功,404:找不到资源,500:服务器内部异常...)。

3) httpResponse.getEntity():从响应对象中获取响应数据HttpEntity对象。

4) ...

 三、请求头

http协议约定,从客户端发出去的请求都带着请求头,请求头里面的信息是为了告诉服务器关于请求的一些信息,比如:客户端支持的数据类型,支持的字符集,支持的语言环境,想要访问的服务器等等。

以客户端浏览器为例,在浏览器中访问登录接口,我们可以通过浏览器的调试器可以看到此请求相关的请求头,另外整理了几个其他较常见的请求头:

  1. User-Agent:告诉服务器客户端的相关信息(如果是浏览器会有版本,内核等信息)
  2. referer:告诉服务器,此请求是从哪个页面上发出来(防盗链)
  3. X-Requested-With:告诉服务器这个是一个ajax请求
  4. Cookie:带给服务器的cookie信息
  5. ...

请求头可以在代码中指定,添加,通过键值对的形式,调用:addHeader(String name,String value)即可在请求对象中添加一个名字为name,值为value的请求头。

四、响应头

类比请求头,服务端的web容器实现了http协议则会在返回头中告诉客户端一些信息,比如:服务器只支持哪种类型的请求,返回的数据长度,数据类型,该怎么样展示等。

仍然以上面浏览器访问登录接口为例,我们在浏览器的调试器中可以看到服务器响应回来的几个响应头信息:

“Set-Cookie”这个响应头的作用是告诉浏览器需要去缓存的cookie数据。如果对于cookie不太明白的同学,可以去我的博客下面看一看这篇文章:https://www.cnblogs.com/nickjiang/p/9148136.html,整理了cookie和session的应用的应用区别。其他几个比较常见的响应头,大家也可以适当了解学习下:

  1. location:告诉浏览器跳到哪里。
  2. content-length:告诉浏览器回送数据的长度。
  3. content-type:告诉浏览器回送数据的类型。
  4. ...

总结:为什么我们除了请求request和响应response外,还需要去了解请求头,响应头?因为我们后面会从响应头里取数据,往请求头里添加数据,这一块的应用会在后面自动化框架的接口鉴权中得到体现

看完本文,相信你已经对上一篇接口调用的代码实现有了更深一步的理解。

接口自动化·分享·第二篇·你必须了解的HttpRequest和HttpResponse的更多相关文章

  1. 基于Python的接口自动化实战-基础篇之pymysql模块操作数据库

    引言 在进行功能或者接口测试时常常需要通过连接数据库,操作和查看相关的数据表数据,用于构建测试数据.核对功能.验证数据一致性,接口的数据库操作是否正确等.因此,在进行接口自动化测试时,我们一样绕不开接 ...

  2. Python自动化 【第二篇】:Python基础-列表、元组、字典

    本节内容 模块初识 .pyc简介 数据类型初识 数据运算 列表.元组操作 字符串操作 字典操作 集合操作 字符编码与转码 一.模块初识 Python的强大之处在于他有非常丰富和强大的标准库和第三方库, ...

  3. 数据库程序接口——JDBC——功能第二篇——数据源之C3P0数据源

    综述 C3P0由三部分内容组成.实例化对象,各配置项的含义,以及加载配置项的方式. 实例化对象的方式有三种,第一种方式直接new ComboPooledDataSource,第二种方式使用工厂类Dat ...

  4. 基于Python的接口自动化实战-基础篇之读写配置文件

    引言 在编写接口自动化测试脚本时,有时我们需要在代码中定义变量并给变量固定的赋值.为了统一管理和操作这些固定的变量,咱们一般会将这些固定的变量以一定规则配置到指定的配置文件中,后续需要用到这些变量和变 ...

  5. java接口自动化(一) - 接口自动化测试整体认知 - 开山篇(超详解)

    简介 了解什么是接口和为什么要做接口测试.并且知道接口自动化测试应该学习哪些技术以及接口自动化测试的落地过程.其实这些基本上在python接口自动化的文章中已经详细的介绍过了,不清楚的可以过去看看.了 ...

  6. python-列表、字典、元组的员工信息处理接口(第二篇(五):基于列表、字典和元组的员工信息处理接口)

    Python之旅]第二篇(五):基于列表.字典和元组的员工信息处理接口 python 列表 字典 元组 员工信息处理接口 摘要: 1.基本需求     编写一个查询员工信息表的程序,实现如下功能: ( ...

  7. 【转载】Android Metro风格的Launcher开发系列第二篇

    前言: 各位小伙伴们请原谅我隔了这么久才开始写这一系列的第二篇博客,没办法忙新产品发布,好了废话不说了,先回顾一下:在我的上一篇博客Android Metro风格的Launcher开发系列第一篇写了如 ...

  8. 第二篇 :微信公众平台开发实战Java版之开启开发者模式,接入微信公众平台开发

    第一部分:微信公众号对接的基本介绍 一.填写服务器配置信息的介绍 登录微信公众平台官网后,进入到公众平台后台管理页面. 选择 公众号基本设置->基本配置 ,点击“修改配置”按钮,填写服务器地址( ...

  9. Python人工智能第二篇

    Python人工智能之路 - 第二篇 : 现成的技术   预备资料: 1.FFmpeg: 链接:https://pan.baidu.com/s/1jonSAa_TG2XuaJEy3iTmHg 密码:w ...

随机推荐

  1. week9:Recommender Systems

    Collaborative  filtering 的原理不是很理解? xi   是每一步电影的特征向量,表示浪漫/动作

  2. Python 自动化paramiko操作linux使用shell命令,以及文件上传下载linux与windows之间的实现

    # coding=utf8 import paramiko """ /* python -m pip install paramiko python version 3. ...

  3. 利用maven开发springMVC项目(二)——框架配置

    申明:主要内容来源于大神博客(使用IntelliJ IDEA开发SpringMVC网站(二)框架配置),我只是用eclipse自己练习使用,记录下来也只是为了学习使用,没有任何的商业用途,侵权必删. ...

  4. NMON监控linux性能

    NMON监控linux性能 一.下载nmon压缩包,下载地址:http://download.csdn.net/download/fhqsse220/6699865 二.安装方法: 1.将nmon_l ...

  5. 关于如何解决bootstrap table 列 切换 刷新 高度不一样

    在使用bootstrap table时候,碰到bootstrap table 列 切换 刷新 高度不一样的问题,如图所示: 解决这个问题很简单,在你的页头加一句<!DOCTYPE html> ...

  6. statsvn,代码统计

    #! /bin/bash # 计算有效变更代码量的脚本 #./svnCount -thttps://192.168.1.1/xxx -s1000 -e2000 -uxxx -pxxx version( ...

  7. 截屏状态监听 - iOS

    既接到电话状态监听的需求之后再次添加了截屏状态的监听,当使用 App 时若用户执行截屏操作需要对当前状态进行监听操作,下面有两种方法,其中可以替换截屏的图片内容(Plan A),也可以弹出提示框(Pl ...

  8. MySQL更新丢失

    MySQL多主结构(比如: MGR Multi Master模式),如果多主都可以写的话,很有可能出现更新丢失的情况. 定义:  T1时间,T2时间,T3时间 定义:  事务A, 事务B Node1节 ...

  9. mac 装5.6版本mysql 设置密码

    最的mysql在装的时候就可以设置 ,但是低版本的好像不行,需要在装了以后才能设置. mac下,mysql5.7.18连接出错,错误信息为:Access denied for user 'root'@ ...

  10. Ubuntu下apt方式安装与更新Git

    本人使用的系统 Ubuntu 18.04.1 ,使用apt安装Git: sudo apt insatll git 安装后发现不是最新的版本,更新方法: sudo add-apt-repository ...