python3 requests session_python3 requests

1 前言

官网中对requests的介绍是"HTTP for Humans"

Requests allows you to send organic, grass-fed HTTP/1.1 requests, without the need for manual labor. There’s no need to manually add query strings to your URLs, or to form-encode your POST data. Keep-alive and HTTP connection pooling are 100% automatic, thanks to urllib3.

GET请求不用&拼接参数,POST请求也毋须编码请求体

总之简单易用,是接口测试和爬虫的必备神器

2 基本使用

2-1 get/post

import requests

//get无参数

r = requests.get('https://httpbin.org/get')

//get有参数,使用params

data = {'key': 'value'}

r = requests.get('https://httpbin.org/get', params=data)

//post有参数,使用data

r = requests.post('https://httpbin.org/post', data = {'key':'value'})

2-2 自定义请求头

headers = {

'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.62 Safari/537.36'

}

r = requests.get('https://httpbin.org/get', headers=headers)

2-3 响应内容

r.content 响应内容的字节码,一般处理二进制文件

r.text 自动选择适当的编码,对r.content解码

r.json() 解析json格式的数据,如果无法解析,则抛出异常

3 API

无论是get/post/delete/put/patch/head/options,都是调用request方法

参数如下:

url 请求的URL地址

params GET请求参数

data POST请求参数

json 同样是POST请求参数,要求服务端接收json格式的数据

headers 请求头字典

cookies cookies信息(字典或CookieJar)

files 上传文件

auth HTTP鉴权信息

timeout 等待响应时间,单位秒

allow_redirects 是否允许重定向

proxies 代理信息

verify 是否校验证书

stream 如果为False,则响应内容将直接全部下载

cert 客户端证书地址

4 Session对象

Session可以持久化请求过程中的参数,以及cookie

尤其是需要登录的网页,使用session可以避免每次的登录操作

s = requests.Session()

s.cookies = requests.cookies.cookiejar_from_dict({'key': 'value'})

r = s.get('https://httpbin.org/cookies')

print(r.text)

===========================

{

"cookies": {

"key": "value"

}

}

另外session还可提供默认值

s = requests.Session()

s.headers.update({'h1':'val1', 'h2':'val2'})

r = s.get('https://httpbin.org/headers', headers={'h2': 'val2_modify'})

print(r.text)

============================

"H1": "val1",

"H2": "val2_modify",

5 Response对象

字段

cookies 返回CookieJar对象

encoding 报文的编码

headers 响应头

history 重定向的历史记录

status_code 响应状态码,如200

elaspsed 发送请求到接收响应耗时

text 解码后的报文主体

content 字节码,可能在raw的基础上解压

方法

json() 解析json格式的响应

iter_content() 需配置stream=True,指定chunk_size大小

iter_lines() 需配置stream=True,每次返回一行

raise_for_status() 400-500之间将抛出异常

close()

6 Prepared Requests

一般情况下,会一次性包装好请求头,请求参数,cookies,鉴权等;但如果通过某些条件判断,可以局部组装requests

s = requests.Session()

req = requests.Request('GET', url='https://httpbin.org/get')

prep = s.prepare_request(req)

headers = {

'User-Agent': 'Chrome/67.0.3396.62'

}

prep.prepare(

method='POST',

url='https://httpbin.org/post',

headers=headers,

data={'key': 'value'}

)

r = s.send(prep)

print(r.text)

===================

{

"args": {},

"data": "",

"files": {},

"form": {

"key": "value"

},

"headers": {

"Accept-Encoding": "identity",

"Connection": "close",

"Content-Length": "9",

"Content-Type": "application/x-www-form-urlencoded",

"Host": "httpbin.org",

"User-Agent": "Chrome/67.0.3396.62"

},

"json": null,

"origin": "xx.xx.xx.xx",

"url": "https://httpbin.org/post"

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值