会话对象
会话对象可以让你的请求默认带上一些缺省的数据
登录后,返回token,原本再次请求是需要带上token认证的,但是会话对象把一些信息设置成默认的,你继续使用这个会话的话,就不需要填写数据了,默认会带上
importrequestss=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数据,那么可以通过此方法获取
importrequestsr=requests.get("https://www.baidu.com") # 响应对象print(r.headers) # 请求对象print(r.request.headers)
带证书访问
客户端带证书访问
秘钥,公钥,及CA证书,都是私发的,那么请求还是会报错的
如果服务端开启了双向认证,那么带证书访问是有必要的
importrequeststest=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证书错误
importrequeststest=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证书
importrequeststest=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)
或设置环境变量
exportREQUESTS_CA_BUNDLE=/Users/jiangyd/Downloads/demo/root.crt
CA 证书
Requests 默认附带了一套它信任的根证书,来自于 Mozilla trust store。然而它们在每次 Requests 更新时才会更新。这意味着如果你固定使用某一版本的 Requests,你的证书有可能已经 太旧了。
从 Requests 2.4.0 版之后,如果系统中装了 certifi 包,Requests 会试图使用它里边的 证书。这样用户就可以在不修改代码的情况下更新他们的可信任证书。
为了安全起见,我们建议你经常更新 certifi!
importcertifiprint(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-----
代理
如果你无法直接访问服务端,需要通过代理的方式才能访问,那么你可以使用如下方法
importrequestsr=requests.get(url="http://172.16.5.9:5003/", proxies={"http": "http://127.0.0.1:8080"}) print(r.status_code) print(r.content)