使用 requests.Session() 可自动保持 Cookie、复用 TCP 连接、统一设置请求头,适用于需登录态或多次交互的场景;普通 requests.get() 每次独立,无法维持会话状态。
使用 requests.Session() 可以自动保持 Cookie、复用 TCP 连接、统一设置请求头,适合需要登录态或多次交互的场景。
普通 requests.get() 每次都是独立请求:Cookie 不保留、连接不复用、参数要重复写。比如登录后访问个人页,没
Session 就拿不到登录态,会跳回登录页。
Session 对象会在内部维护一个 cookie jar,并在后续请求中自动携带服务端返回的 Cookie,实现“会话保持”。
只需三步:
session = requests.Session()
session.post() 登录(获取并保存 Cookie)session.get() 访问需登录的页面(自动带上 Cookie)示例:
import requestss = requests.Session()
登录(假设表单字段是 username/password)
s.post("https://www./link/d9976f1c2c0c972d1cee0c3647cbd194", data={"username": "user", "password": "123"})
后续请求自动携带登录态
resp = s.get("https://www./link/6499e19d47d7cbd3302a26fdb40d0b41") print(resp.text) # 能看到个人页内容,不是重定向到登录页
避免每次传参,可统一配置:
s.headers.update({"User-Agent": "MyApp/1.0"}) —— 所有请求自带 UAs.timeout = 5 或在方法中加 timeout=5 —— 防卡死s.verify = False(仅测试环境)—— 忽略 SSL 证书验证注意:headers 是字典,用 update() 或直接赋值;timeout 不是 Session 属性,需在每个请求方法里显式传入,但可封装成函数简化。
Session 不是万能的:
s.cookies.set("key", "value", domain="example.com")
print(s.cookies.get_dict()) 查看当前 Cookie不复杂但容易忽略