Python库request高级部分用法

会话对象


会话对象可以让你的请求默认带上一些缺省的数据


登录后,返回token,原本再次请求是需要带上token认证的,但是会话对象把一些信息设置成默认的,你继续使用这个会话的话,就不需要填写数据了,默认会带上

import requests
s=requests.session()
resp=s.post(url="http://testing-ft2x-api.cloudcare.cn/api/v1/auth-token/login",json={"username":"jiangyd@jiagouyun.com","password":"Qwe123123"})
s.headers["X-FT-Auth-Token"]=resp.json()["content"]["token"]
resp=s.get("http://testing-ft2x-api.cloudcare.cn/api/v1/workspace/member/list?pageIndex=1&pageSize=2")
print(resp.json())

请求与响应对象

如果你想获取发送了那些headers数据,那么可以通过此方法获取

import requests
r = requests.get("https://www.baidu.com")
# 响应对象
print(r.headers)
# 请求对象
print(r.request.headers)

带证书访问


客户端带证书访问

秘钥,公钥,及CA证书,都是私发的,那么请求还是会报错的


如果服务端开启了双向认证,那么带证书访问是有必要的

import requests
test = requests.get("https://www.jiangyd.cn:7443/test/stats",
                    cert=("/Users/jiangyd/Downloads/demo/client.crt", "/Users/jiangyd/Downloads/demo/client.key"))
print(test.status_code)


还是需要忽略CA证书错误

import requests
test = requests.get("https://www.jiangyd.cn:7443/test/stats",
                    cert=("/Users/jiangyd/Downloads/demo/client.crt", "/Users/jiangyd/Downloads/demo/client.key"),
                    verify=False)
print(test.status_code)


或指定CA证书

import requests
test = requests.get("https://www.jiangyd.cn:7443/test/stats",
                    cert=("/Users/jiangyd/Downloads/demo/client.crt", "/Users/jiangyd/Downloads/demo/client.key"),
                    verify="/Users/jiangyd/Downloads/demo/root.crt")
print(test.status_code)


或设置环境变量

export REQUESTS_CA_BUNDLE=/Users/jiangyd/Downloads/demo/root.crt


CA 证书

Requests 默认附带了一套它信任的根证书,来自于 Mozilla trust store。然而它们在每次 Requests 更新时才会更新。这意味着如果你固定使用某一版本的 Requests,你的证书有可能已经 太旧了。

从 Requests 2.4.0 版之后,如果系统中装了 certifi 包,Requests 会试图使用它里边的 证书。这样用户就可以在不修改代码的情况下更新他们的可信任证书。

为了安全起见,我们建议你经常更新 certifi!


import certifi
print(certifi.where())

我这边输出的结果是:

/Users/jiangyd/PycharmProjects/untitled14/venv/lib/python3.7/site-packages/certifi/cacert.pem

vim cacert.pem 编辑此文件,在文件末尾增加上CA证书的内容

-----BEGIN CERTIFICATE-----
MIICZTCCAc4CCQC4CU2F+nNw7zANBgkqhkiG9w0BAQsFADB3MQswCQYDVQQGEwJj
bjELMAkGA1UECAwCc2gxCzAJBgNVBAcMAnNoMQ8wDQYDVQQKDAZ6aHV5dW4xDTAL
BgNVBAsMBHRlc3QxDTALBgNVBAMMBHJvb3QxHzAdBgkqhkiG9w0BCQEWEDk2MjU4
NDkwMkBxcS5jb20wHhcNMjEwMzI5MjIwMDA3WhcNMzEwMzI3MjIwMDA3WjB3MQsw
CQYDVQQGEwJjbjELMAkGA1UECAwCc2gxCzAJBgNVBAcMAnNoMQ8wDQYDVQQKDAZ6
aHV5dW4xDTALBgNVBAsMBHRlc3QxDTALBgNVBAMMBHJvb3QxHzAdBgkqhkiG9w0B
CQEWEDk2MjU4NDkwMkBxcS5jb20wgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGB
AMRzEUF1FIeC0wvhp2fofBHES0ePmG9k2zYYLLloXbv41jXuQJDYvvb1A+HDxLhb
Vlrg4qa2yMhM2aWNoup1cko9YrvZ9twEVluGbdjsIosF9/lxZWbOcPOXdcrAPRMp
FW1krxtQSnMTbMSRcTys8tJS/AE8UbsFs0qgciD5FEE1AgMBAAEwDQYJKoZIhvcN
AQELBQADgYEAcAe28v3mnVaG9XDMQQvOiLsva+N6dgeLfg3v+4JlsA3HJ+YpVTVn
bQN85mOoF8CN5b5GnZxKfguJcIokPOxi29H53GRNMuDtFcucrKyaT6kLnfSkE3gg
3dG0C24n1qVZyplhwLaWiJDLQzw/S7UtfNJvihYu1ZO1V/wOnC53egk=
-----END CERTIFICATE-----


代理

如果你无法直接访问服务端,需要通过代理的方式才能访问,那么你可以使用如下方法

import requests
r = requests.get(url="http://172.16.5.9:5003/", proxies={"http": "http://127.0.0.1:8080"})
print(r.status_code)
print(r.content)
上一篇:Ubuntu 本地网卡不能上网处理方法


下一篇:AI公开课:19.03.07雷鸣教授《人工智能革命与趋势》课堂笔记以及个人感悟