Requests 是使用 Apache2 Licensed 许可证的 基于Python开发的HTTP 库,其在Python内置模块的基础上进行了高度的封装,从而使得Pythoner进行网络请求时,变得美好了许多,使用Requests可以轻而易举的完成浏览器可有的任何操作。
GET 请求
# 1、无参数实例 import requests ret = requests.get(\'https://github.com/timeline.json\') print ret.url print ret.text # 2、有参数实例 import requests payload = {\'key1\': \'value1\', \'key2\': \'value2\'} ret = requests.get(\"http://httpbin.org/get\", params=payload) print ret.url print ret.text
POST 请求
# 1、基本POST实例 import requests payload = {\'key1\': \'value1\', \'key2\': \'value2\'} ret = requests.post(\"http://httpbin.org/post\", data=payload) print ret.text # 2、发送请求头和数据实例 import requests import json url = \'https://api.github.com/some/endpoint\' payload = {\'some\': \'data\'} headers = {\'content-type\': \'application/json\'} ret = requests.post(url, data=json.dumps(payload), headers=headers) print ret.text print ret.cookies
其他请求
requests.get(url, params=None, **kwargs) requests.post(url, data=None, json=None, **kwargs) requests.put(url, data=None, **kwargs) requests.head(url, **kwargs) requests.delete(url, **kwargs) requests.patch(url, data=None, **kwargs) requests.options(url, **kwargs) # 以上方法均是在此方法的基础上构建 requests.request(method, url, **kwargs)
requests.request() 参数
method:提交方式 get/post 。
url:提交地址。
params:在URL上传递的参数,GET形式传递到后台,例如向http://www.oldboyyede.com上传数据。
requests.request( method = \'GET\', url = \'http://www.oldboyyede.com\', params = { \'k1\' : \'v1\' , \'k2\' : \'v2\' } ) # http://www.oldboyyede.com?k1=v1&k2=v2
data:在请求体里面传递的数据,后面可以是字典,字节等数据类型。
requests.request( method = \'POST\', url = \'http://www.oldboyyede.com\', # data= { \'k1\' : \'v1\' , \'k2\' : \'v2\' , \'x\':[1,2,3]} data=\" user=wjw&pwd=123123 \" )
json:在请求体里面传递数据,把整体序列化成一个大字符串,字典中嵌套字典的话用JSON 。
requests.request( method = \'POST\', url = \'http://www.oldboyyede.com\', json= { \'k1\' : \'v1\' , \'k2\' : \'v2\' } ) # \"{ \'k1\' : \'v1\' , \'k2\' : \'v2\' }\"
headers:请求头。
一定要添加浏览器,不然可能会遇到网络防火墙
headers = {\’User-Agent\’: \’Mozilla/5.0 (Windows NT 10.0; WOW64; rv:58.0) Gecko/20100101 Firefox/58.0\’}
# 一定要添加浏览器,不然可能会遇到网络防火墙拦截你的请求 headers = {\'User-Agent\': \'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:58.0) Gecko/20100101 Firefox/58.0\'} r1 = requests.get( url=\'http://dig.chouti.com/\', headers=headers )
files:上传文件对象。
# 模块的详细使用 import requests requests.post( url=\'xxxxxx\', files={ # \'f1\':open(\'s1.py\',\'rb\') # 可以上传元祖的形式上传,sssss1.py为后台获取的名称 \'f1\': open(\'sssss1.py\',(\'s1.py\', \'rb\')) } )
参数实例
def param_method_url(): # requests.request(method=\'get\', url=\'http://127.0.0.1:8000/test/\') # requests.request(method=\'post\', url=\'http://127.0.0.1:8000/test/\') pass def param_param(): # - 可以是字典 # - 可以是字符串 # - 可以是字节(ascii编码以内) # requests.request(method=\'get\', # url=\'http://127.0.0.1:8000/test/\', # params={\'k1\': \'v1\', \'k2\': \'水电费\'}) # requests.request(method=\'get\', # url=\'http://127.0.0.1:8000/test/\', # params=\"k1=v1&k2=水电费&k3=v3&k3=vv3\") # requests.request(method=\'get\', # url=\'http://127.0.0.1:8000/test/\', # params=bytes(\"k1=v1&k2=k2&k3=v3&k3=vv3\", encoding=\'utf8\')) # 错误 # requests.request(method=\'get\', # url=\'http://127.0.0.1:8000/test/\', # params=bytes(\"k1=v1&k2=水电费&k3=v3&k3=vv3\", encoding=\'utf8\')) pass def param_data(): # 可以是字典 # 可以是字符串 # 可以是字节 # 可以是文件对象 # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # data={\'k1\': \'v1\', \'k2\': \'水电费\'}) # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # data=\"k1=v1; k2=v2; k3=v3; k3=v4\" # ) # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # data=\"k1=v1;k2=v2;k3=v3;k3=v4\", # headers={\'Content-Type\': \'application/x-www-form-urlencoded\'} # ) # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # data=open(\'data_file.py\', mode=\'r\', encoding=\'utf-8\'), # 文件内容是:k1=v1;k2=v2;k3=v3;k3=v4 # headers={\'Content-Type\': \'application/x-www-form-urlencoded\'} # ) pass def param_json(): # 将json中对应的数据进行序列化成一个字符串,json.dumps(...) # 然后发送到服务器端的body中,并且Content-Type是 {\'Content-Type\': \'application/json\'} requests.request(method=\'POST\', url=\'http://127.0.0.1:8000/test/\', json={\'k1\': \'v1\', \'k2\': \'水电费\'}) def param_headers(): # 发送请求头到服务器端 requests.request(method=\'POST\', url=\'http://127.0.0.1:8000/test/\', json={\'k1\': \'v1\', \'k2\': \'水电费\'}, headers={\'Content-Type\': \'application/x-www-form-urlencoded\'} ) def param_cookies(): # 发送Cookie到服务器端 requests.request(method=\'POST\', url=\'http://127.0.0.1:8000/test/\', data={\'k1\': \'v1\', \'k2\': \'v2\'}, cookies={\'cook1\': \'value1\'}, ) # 也可以使用CookieJar(字典形式就是在此基础上封装) from http.cookiejar import CookieJar from http.cookiejar import Cookie obj = CookieJar() obj.set_cookie(Cookie(version=0, name=\'c1\', value=\'v1\', port=None, domain=\'\', path=\'/\', secure=False, expires=None, discard=True, comment=None, comment_url=None, rest={\'HttpOnly\': None}, rfc2109=False, port_specified=False, domain_specified=False, domain_initial_dot=False, path_specified=False) ) requests.request(method=\'POST\', url=\'http://127.0.0.1:8000/test/\', data={\'k1\': \'v1\', \'k2\': \'v2\'}, cookies=obj) def param_files(): # 发送文件 # file_dict = { # \'f1\': open(\'readme\', \'rb\') # } # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # files=file_dict) # 发送文件,定制文件名 # file_dict = { # \'f1\': (\'test.txt\', open(\'readme\', \'rb\')) # } # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # files=file_dict) # 发送文件,定制文件名 # file_dict = { # \'f1\': (\'test.txt\', \"hahsfaksfa9kasdjflaksdjf\") # } # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # files=file_dict) # 发送文件,定制文件名 # file_dict = { # \'f1\': (\'test.txt\', \"hahsfaksfa9kasdjflaksdjf\", \'application/text\', {\'k1\': \'0\'}) # } # requests.request(method=\'POST\', # url=\'http://127.0.0.1:8000/test/\', # files=file_dict) pass <br> # 做基本认证 header中加密的用户名和密码 def param_auth(): from requests.auth import HTTPBasicAuth, HTTPDigestAuth ret = requests.get(\'https://api.github.com/user\', auth=HTTPBasicAuth(\'wangjiawei\', \'sdfasdfasdf\')) print(ret.text) # ret = requests.get(\'http://192.168.1.1\', # auth=HTTPBasicAuth(\'admin\', \'admin\')) # ret.encoding = \'gbk\' # print(ret.text) # ret = requests.get(\'http://httpbin.org/digest-auth/auth/user/pass\', auth=HTTPDigestAuth(\'user\', \'pass\')) # print(ret) # # 请求和响应的超时时间 def param_timeout(): # ret = requests.get(\'http://google.com/\', timeout=1) # print(ret) # ret = requests.get(\'http://google.com/\', timeout=(5, 1)) # print(ret) pass <br> # 是允许否重定向 def param_allow_redirects(): ret = requests.get(\'http://127.0.0.1:8000/test/\', allow_redirects=False) print(ret.text) <br> # 代理 出口IP 不是本机IP。 流程是:先给代理发,代理帮助我们向目的地址发。 def param_proxies(): # proxies = { # \"http\": \"61.172.249.96:80\", # \"https\": \"http://61.185.219.126:3128\", # } # proxies = {\'http://10.20.1.128\': \'http://10.10.1.10:5323\'} # ret = requests.get(\"http://www.proxy360.cn/123456\", proxies=proxies) # print(ret.headers) # from requests.auth import HTTPProxyAuth # # proxyDict = { # \'http\': \'77.75.105.165\', # \'https\': \'77.75.105.165\' # } # auth = HTTPProxyAuth(\'username\', \'mypassword\') # # r = requests.get(\"http://www.google.com\", proxies=proxyDict, auth=auth) # print(r.text) pass <br> # 流形式 比如下片 def param_stream(): ret = requests.get(\'http://127.0.0.1:8000/test/\', stream=True) print(ret.content) ret.close() # from contextlib import closing # with closing(requests.get(\'http://httpbin.org/get\', stream=True)) as r: # # 在此处理响应。迭代处理 # for i in r.iter_content(): # print(i) def requests_session(): import requests session = requests.Session() ### 1、首先登陆任何页面,获取cookie i1 = session.get(url=\"http://dig.chouti.com/help/service\") ### 2、用户登陆,携带上一次的cookie,后台对cookie中的 gpsd 进行授权 i2 = session.post( url=\"http://dig.chouti.com/login\", data={ \'phone\': \"8612345678977\", \'password\': \"xxxxxx\", \'oneMonth\': \"\" } ) i3 = session.post( url=\"http://dig.chouti.com/link/vote?linksId=8589623\", ) print(i3.text)
http 与 https 区别
- http
本质上就是 socket,http 请求不安全,因为没有任何的加密措施。
- https
拥有加密措施,ssh 加密,有证书一说,服务器给请求的客户端颁发证书,客户端使用证书对客户端发送的数据加密成密文,然后发送给服务器,服务器通过证书进行解密,检测是否是匹配的,进行传输信息。通信间必须使用证书。cert参数是证书,主动提供证书,可以自己制作(缺钱的话),比如证书是“fuck.pem”,cert=(\’fuck.pem\’),必须使用证书,如果没有证书则不能进行通信。还有一类证书需要自己买的第三方可信赖的证书,系统在创建(一装机)的时候直接植入证书,厂商帮忙做验证,这就是有钱和没钱的区别,用户不需要自己在浏览器上安装证书了,pem是证书的格式,cert=(\’fuck.crt\’,\’xxx.key\’),和自己办法的没区别,需要啥样给啥样,完成的事都是做加密使用。还有一个参数叫 verify,如果 verify=False,则表示忽略证书,直接发请求直接拿结果,一般网站是允许用的,但是服务器必须要证书也白搭。
以上就是python request 模块详细介绍的详细内容,更多关于python request 模块的资料请关注自学编程网其它相关文章!