news 2026/4/29 14:44:57

python接口自动化 —— 发送get请求接口(详解)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
python接口自动化 —— 发送get请求接口(详解)

简介

如果想用python做接口测试,我们首先有不得不了解和学习的模块。它就是第三方模块:Requests。虽然Python内置的urllib模块,用于访问网络资源。但是,它用起来比较麻烦,而且,缺少很多实用的高级功能。更好的方案是使用

requests。它是一个Python第三方库,处理URL资源特别方便。查看其中文官网:Requests: 让 HTTP 服务人类 — Requests 2.18.1 文档英文官网:http://www.python-requests.org/en/master/可以看一下它的很多实用的高级功能。

功能特性

Requests 完全满足今日 web 的需求。

  • Keep-Alive & 连接池
  • 国际化域名和 URL
  • 带持久 Cookie 的会话
  • 浏览器式的 SSL 认证
  • 自动内容解码
  • 基本/摘要式的身份认证
  • 优雅的 key/value Cookie
  • 自动解压
  • Unicode 响应体
  • HTTP(S) 代理支持
  • 文件分块上传
  • 流下载
  • 连接超时
  • 分块请求
  • 支持.netrc

环境安装(安装requests)

您如果安装了Anaconda,requests就已经可用了。否则,需要在命令行下通过pip安装:

pip install requests

注意:pip很容易就会版本升级,

方法1:检测并更新

pip list –outdated

方法2:

♦先卸载:

pip uninstall packagename

♦在用:easy_install.exe安装

easy_install.exe pip

出现Installing collected packages: idna, chardet, certifi, requests

Successfully installed certifi-2019.3.9 chardet-3.0.4 idna-2.8 requests-2.21.0 说明requests模块安装成功!

使用requests(get请求无参数param)

1、将安装好的requests模块导入后,通过GET访问一个URL地址的网页页面,如:https://www/douban.com

2、这里的 r 也就是 response,请求后的返回值,可以调用 response 里的 status_code 方法查看状态码

3、状态码 200 只能说明这个接口访问的服务器地址是对的,并不能说明功能 OK,一般要查看响应的内容,r.text 是返回文本信息

看吧!这个就是requests的威力,看起来是不是很神奇很牛逼:

使用requests(get请求有参数param)

1、再发一个带参数的 get 请求,如在豆瓣网搜索:西游记,url 地址为:https://www.douban.com/search?q=西游记

2、请求参数:q=西游记,可以以字典的形式传参:{"q": "西游记"}

3、多个参数格式:{"key1": "value1", "key2": "value2", "key3": "value3"}

这部分最容易犯错的部分,就是1、豆瓣网址后没有+/search;2、params错误的写成param

使用request(get获取响应文本content)

1、豆瓣网首页如果用 r.text 会发现获取到的内容有乱码,因为豆瓣网首页响应内容是 gzip 压缩的(非 text 文本)

2、如果是在 fiddler 工具乱码,是可以点击后解码的,在代码里面可以用 r.content 这个方法,content 会自动解码 gzip 和 deflate 压缩(这个就是开始介绍requests的高级功能:自动解码和自动解压)

附录response返回的其他信息

1.response 的返回内容(content)还有其它更多信息

-- r.status_code #响应状态码

-- r.content #字节方式的响应体,会自动为你解码 gzip 和deflate 压缩

-- r.headers #以字典对象存储服务器响应头,但是这个字典比较特殊,字典键不区分大小写,若键不存在则返回 None

-- r.json() #Requests 中内置的 JSON 解码器,requests的方便之处还在于,对于特定类型的响应,例如JSON,可以直接获取

-- r.url # 获取 url

-- r.encoding # 编码格式,requests自动检测编码

-- r.cookies # 获取 cookie

-- r.raw #返回原始响应体-- r.text #字符串方式的响应体,会自动根据响应头部的字符编码进行解码

-- r.raise_for_status() #失败请求(非 200 响应)抛出异常

小结

用requests发送get请求的接口,就是这么简单!想要学的赶快行动起来,键盘敲起来,你可以自己练习一下。

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 10:54:46

Langchain-Chatchat构建IT运维知识库的落地实践

Langchain-Chatchat构建IT运维知识库的落地实践 在企业IT系统日益复杂的今天,一线运维工程师常常面临一个尴尬的局面:明明公司有厚厚的《故障处理手册》《系统配置指南》和上百份应急响应文档,但当服务器突然宕机、数据库主从同步中断时&…

作者头像 李华
网站建设 2026/4/23 14:41:57

Langchain-Chatchat结合Neo4j图数据库的知识建模

Langchain-Chatchat 结合 Neo4j 图数据库的知识建模 在企业智能化转型的浪潮中,一个反复出现的挑战是:如何让 AI 助手真正“懂”自家的知识?通用大模型虽然能谈天说地,但面对内部文档、技术手册或组织架构时,往往答非所…

作者头像 李华
网站建设 2026/4/29 4:03:14

Langchain-Chatchat如何实现问答过程的日志审计?

Langchain-Chatchat 如何实现问答过程的日志审计? 在企业级 AI 应用日益普及的今天,一个看似简单的“问与答”背后,往往牵涉到数据安全、合规审查和责任追溯等严肃问题。尤其是在金融、医疗、政务等敏感领域,AI 不只是助手&#x…

作者头像 李华
网站建设 2026/4/25 9:54:27

随机森林(初步学习)

随机森林是一种集成学习(Ensemble Learning) 算法,核心思想是构建多个决策树,通过投票或平均的方式输出结果,以此降低单一决策树过拟合的风险,提升模型的泛化能力。它在机器学习的分类、回归、特征重要性评…

作者头像 李华