Python网络请求库requests使用详述

news/2025/9/21 13:43:07/文章来源:https://www.cnblogs.com/eic85764/p/19103579

Python的 requests库是一种广泛使用的HTTP客户端库,它允许你发送HTTP/1.1请求易如反掌。它的设计目标是使HTTP请求对开发者来说尽可能得简单快捷。requests库遵循RFC 7231的HTTP协议标准,并提供了多种功能,比如会话对象、持久连接和请求钩子。

安装

你可以使用 pip安装 requests库:

pip install requests

创建请求

发送请求最简单的方式是直接使用 requests.getrequests.post等函数:

import requests
response = requests.get('https://api.example.com/data')

requests同样支持其他HTTP方法,如 HEADPUTDELETEPATCHOPTIONS

请求参数

发送GET请求时,可以使用 params关键字参数来提供URL参数:

payload = {'key1': 'value1', 'key2': 'value2'}
response = requests.get('https://httpbin.org/get', params=payload)

对于POST请求,可以使用 data关键字参数来提供表单数据:

payload = {'key1': 'value1', 'key2': 'value2'}
response = requests.post("https://api.example.com/post", data=payload)

请求头部

请求的头部可以通过一个字典传递给 headers参数:

headers = {'user-agent': 'my-app/0.0.1'}
response = requests.get('https://api.example.com/data', headers=headers)

JSON请求

requests可以很方便的处理JSON类型的请求,通过简单地传递一个字典给 json参数,它会自动被转换成JSON:

response = requests.post('https://api.example.com/data', json={"my": "data"})

响应内容

响应的内容可以通过 response.text来访问,这会返回一个Unicode形式的响应文本。为了获取字节形式的响应体,你可以访问 response.content

print(response.text)

如果响应是JSON格式,可以直接用 response.json()方法来解析:

print(response.json())

错误处理

requests可以通过 response.raise_for_status()来抛出异常,当遇到网络问题(例如:DNS查询失败、拒绝连接等)或失效的HTTP响应时。

try:response.raise_for_status()
except requests.exceptions.HTTPError as err:print(err)

超时

你可以告诉 requests库,它应该等待多久连接和读取数据的超时时间。

response = requests.get('https://api.example.com/data', timeout=1)

这里的超时时间是秒为单位。

会话对象

为了同一站点上的多个请求维护一些持久化的连接,你可以使用会话对象。会话对象也可以跨请求保持某些参数。

with requests.Session() as session:session.headers.update({'x-test': 'true'})response = session.get('https://httpbin.org/headers', headers={'x-test2': 'false'})

会话还可以用于持久化某些参数,如cookies。

安全和身份验证

requests支持多种身份验证形式,最简单的是HTTP基本认证:

from requests.auth import HTTPBasicAuth
response = requests.get('https://api.example.com/data', auth=HTTPBasicAuth('user', 'pass'))

同时也支持摘要认证、OAuth认证等。

SSL证书验证

默认情况下,requests会验证HTTPS请求的SSL证书,如果证书验证失败,它会抛出一个 SSLError。你可以通过设置 verify=False来忽略SSL证书验证,但这通常是不推荐的,因为它会降低安全性。

response = requests.get('https://api.example.com/data', verify=False)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/908788.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构与排序算法:从理论到场景,解锁高效数据处理的核心逻辑 - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Composer在PHP项目中的手动类自动加载策略

在PHP项目中,当不使用Composer的自动加载功能时,我们需要自己实现自动加载机制以便于管理和加载项目中的类文件。一个手动的类自动加载策略通常遵循PSR(PHP标准推荐)中的自动加载标准,典型的如PSR-4。以下是一个具…

2025-2026-1 20231301 《信息安全设计》第二周学习总结

View Post2025-2026-1 20231301 《信息安全设计》第二周学习总结2025-2026-1 20231301 《信息安全设计》第二周学习总结 目录作业信息学习内容总结《Head First C 嗨翻C语⾔》 第八章静态库与动态库基本概念创建与使用…

内存超频最强的千元板!微星B850MPOWER主板评测

内存超频最强的千元板!微星B850MPOWER主板评测Posted on 2025-09-21 13:37 lzhdim 阅读(0) 评论(0) 收藏 举报一、前言:专为内存超频而生的主板 对于新一代AMD锐龙9000处理器而言,超频内存所能带来的游戏帧率提…

window表现驱动开发—视频呈现网络简介

window表现驱动开发—视频呈现网络简介pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Mon…

完整教程:第7.9节:awk语言 nextfile 语句

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Docker - Create my own Ubuntu image and run it on Windows

Docker - Create my own Ubuntu image and run it on Windows1. Pull the ubuntu:24.04 image.2. Set shared directory so that I can operate on files in both Windows and the container: 3. Create the Dockerfi…

一类特征方程在数列递推中的应用

以下内容摘自《组合数学》(第五版)P86【例 2-41】。求 \(S_n=1^3+2^3+\cdots+n^3\)。\(\Delta S_n=S_{n+1}-S_n=(n+1)^3\) 是 \(n\) 的 \(3\) 次多项式,因此 \(S_n\) 满足递推关系: \[S_n-5S_{n-1}+10S_{n-2}-10S_…

深入解析:GC 算法的种类及垃圾收集器

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

rust跨文件调用代码

cargo new my_testcd my_tescode .目录如下我们假设我们想要开发一个学生管理系统,于是添加模块"student_find" 添加mod.rs student.rs在mod.rs里编写pub mod student; 在student.rs里编写接口体/函数即可…

详细介绍:导师推荐毕设:基于SpringBoot+Vue的中小企业进销存管理系统设计

详细介绍:导师推荐毕设:基于SpringBoot+Vue的中小企业进销存管理系统设计pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-famil…

HarmonyOS之UIContext - 实践

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

NIO重构UDP收发模块

本文大纲如下:1、写作背景 2、基本的UDP包收发用法 3、采用NIO方式处理UDP一、背景 本篇内容,主要来源是在对公司代码重构。公司一个项目是采用UDP方式通信,在UDP的不可靠基础上,封装成可靠的通信协议。其本质是UD…

深入解析:C语言:猜数字游戏

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

深入解析:深度学习从入门到精通 - AutoML与神经网络搜索(NAS):自动化模型设计未来

深入解析:深度学习从入门到精通 - AutoML与神经网络搜索(NAS):自动化模型设计未来2025-09-21 12:39 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; ove…

题解:SP6562 PRUBALL - Esferas

盲猜你们都是从 CSP-S 2025 初赛 来的…… 题目描述 给你 \(n\) 颗蛋和一个 \(m\) 层高的楼,定义蛋的硬度 \(k\) 为:在 \(<k\) 的楼层扔蛋不会碎,在 \(\ge k\) 的楼层扔蛋会碎。求在最坏情况下,最少需要扔多少次…

个人项目-文本查重

软工第二次作业之个人项目——论文查重 项目信息项目信息 详情课程 班级链接作业要求 作业要求项目目标 实现一个论文查重程序,规范软件开发流程,熟悉Github进行源代码管理和学习软件测试GitHub仓库 https://github.…

深入解析:[数据结构] LinkedList

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

US$34 MB ESL Emulator

MB ESL EmulatorTop 4 Reasons To Get MB ESL Emulator1. This device works with Mercedes EIS.2. It emulates both of old (W202, 208, 210) and new (203, 208, 211, 639).3. ESL types functioning.You can use t…

采用python test测试http接口

采用python test测试http接口pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco"…