news 2026/4/24 21:20:21

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 11:31:36

基于GUI-PLUS 搭配 Java Robot 实现智能桌面操控

目录 一、引言 二、代码实现 1. 新增工具类 CoordinateExtractUtil 1.1 核心方法说明 2. DesktopRobotUtil 修改 2.1 功能概述 2.2 核心方法解析 鼠标操作 键盘操作 滚轮操作 注意事项 3. OperationController 接口 三、结果演示 一、引言 在前文 基于GUI-PLUS 的桌…

作者头像 李华
网站建设 2026/4/17 17:07:43

Langchain-Chatchat实现多租户知识隔离的技术方案

Langchain-Chatchat 实现多租户知识隔离的技术方案 在企业智能化转型加速的今天,越来越多组织开始构建基于大语言模型(LLM)的本地知识库系统。然而,一个现实难题摆在面前:如何让多个部门、子公司甚至外部客户共享同一套…

作者头像 李华
网站建设 2026/4/22 14:02:22

震撼发现!GPT-5记忆系统不用RAG?四大层级架构详解(建议收藏)

本文通过逆向工程揭秘GPT-5记忆系统架构,发现其摒弃了传统向量数据库和RAG技术,转而采用四大层级:会话元数据、用户记忆、近期对话摘要和当前会话滑动窗口。这种分层设计既实现了个性化体验,又避免了高计算开销,在速度…

作者头像 李华
网站建设 2026/4/17 16:53:28

AI应用架构师主动学习实践:解决实际难题

AI应用架构师主动学习实践:解决实际难题 关键词:AI应用架构师、主动学习、实际难题、数据处理、模型优化、应用部署 摘要:本文深入探讨AI应用架构师在主动学习方面的实践,旨在解决实际工作中面临的各类难题。通过阐述主动学习的概…

作者头像 李华
网站建设 2026/4/21 18:06:50

Pandas库基础概念和基础操作

Pandas 是 Python 中用于数据分析和处理最流行的开源库之一,建立在 NumPy 之上,提供了高性能、易用的数据结构和数据分析工具。它特别适合处理结构化数据(如表格型或异质型数据)。以下是 Pandas 的基础概念详细介绍:一…

作者头像 李华