網站首頁 編程語言 正文
一、requests
request的說法網上有很多,簡單來說就是就是python里的很強大的類庫,可以幫助你發很多的網絡請求,比如get,post,put,delete等等,這里最常見的應該就是get和post
二、requests安裝方式
$ pip install requests
$ easy_install requests
三、說說常見的兩種請求,get和post
1、get請求
(1)參數直接跟在url后面,即url的“ ?”后面,以key=value&key=value的形式
(2)由于get的參數是暴露在外面的,所以一般不傳什么敏感信息,經常用于查詢等操作
(3)由于參數是跟在url后面的,所以上傳的數據量不大
2、post請求
(1)參數可以寫在url后面,也可以寫在body里面
(2)用body上傳請求數據,上傳的數據量比get大
(3)由于寫在body體里,相對安全
post正文格式
(1)form表單 ?html提交數據的默認格式
? ? ? ? ? ? ? ? ? ? ? ? ? Content-Type: application/x-www-form-urlencoded
? ? ? ? ? ? ? ? ? ? ? ? ? 例如: username=admin&password123
? (2) multipart-form-data . 復合表單 可轉數據+文件
(3)純文本格式 raw ,最常見的 json . xml html js
? ? ? ? Content-Type:application/json . text/xml . text/html
? ?(4) binary . 二進制格式:只能上傳一個文件
四、requests發送請求
1、requests發送get請求
url = "http://www.search:9001/search/"
param = {"key":"你好"}
res = requests.get(url=url, params=params)
2、request發送post請求 (body是json格式,如果還帶cookie)
headers = {'Content-Type': 'application/json'} #必須有
url = "http://www.search:9001/search/"
data= {"key":"你好"}
cookies = {"uid":"1"}
res = requests.post(url=url, headers=headers, data=data, cookies=cookies)
3、 request發送post請求 (body是urlencoded格式)
url = "http://www.search:9001/search/"
data= {"key":"你好"}
res = requests.post(url=url, headers=headers)
4、 request上傳文件
def post_file_request(url, file_path):
if os.path.exists(file_path):
if url not in [None, ""]:
if url.startswith("http") or url.startswith("https"):
files = {'file': open(file_path, 'rb')}
res = requests.post(url, files=files, data=data)
return {"code": 0, "res": res}
else:
return {"code": 1, "res": "url格式不正確"}
else:
return {"code": 1, "res": "url不能為空"}
else:
return {"code": 1, "res": "文件路徑不存在"}
五、response
request發送請求后,會返回一個response,response里有好多信息,我進行了一下封裝,基本如下
@staticmethod
def get_response_text(response):
if response not in [None, ""]:
if isinstance(response, requests.models.Response):
return {"code": 0, "res": response.text.encode('utf-8').decode('unicode_escape')} #這種方式可以將url編碼轉成中文,返回響應文本
else:
return {"code": 1, "res": "response不合法"}
else:
return {"code": 1, "res": "response對像不能為空"}
@staticmethod
def get_response_status_code(response):
if response not in [None, ""]:
if isinstance(response, requests.models.Response):
return {"code": 0, "res": response.status_code} #返回響應狀態嗎
else:
return {"code": 1, "res": "response不合法"}
else:
return {"code": 1, "res": "response對像不能為空"}
@staticmethod
def get_response_cookies(response):
if response not in [None, ""]:
if isinstance(response, requests.models.Response):
return {"code": 0, "res": response.cookies} #返回cookies
else:
return {"code": 1, "res": "response不合法"}
else:
return {"code": 1, "res": "response對像不能為空"}
@staticmethod
def get_response_headers(response):
if response not in [None, ""]:
if isinstance(response, requests.models.Response):
return {"code": 0, "res": response.headers} #返回headers
else:
return {"code": 1, "res": "response不合法"}
else:
return {"code": 1, "res": "response對像不能為空"}
@staticmethod
def get_response_encoding(response):
if response not in [None, ""]:
if isinstance(response, requests.models.Response):
return {"code": 0, "res": response.encoding} #返回編碼格式
else:
return {"code": 1, "res": "response不合法"}
else:
return {"code": 1, "res": "response對像不能為空"}
補充:requests中遇到問題
獲取cookie
# -*- coding:utf-8 -*-
#獲取cookie
import requests
import json
url = "https://www.baidu.com/"
r = requests.get(url)
#將RequestsCookieJar轉換成字典
c = requests.utils.dict_from_cookiejar(r.cookies)
print(r.cookies)
print(c)
for a in r.cookies:
? ? print(a.name,a.value)
>> 控制臺輸出:
<RequestsCookieJar[<Cookie BDORZ=27315 for .baidu.com/>]>
{'BDORZ': '27315'}
BDORZ 27315
發送Cookie
# -*- coding:utf-8 -*-
#發送cookie到服務器
import requests
import json
host = "*****"
endpoint = "cookies"
url = ''.join([host,endpoint])
#方法一:簡單發送
# cookies = {"aaa":"bbb"}
# r = requests.get(url,cookies=cookies)
# print r.text
#方法二:復雜發送
s = requests.session()
c = requests.cookies.RequestsCookieJar()
c.set('c-name','c-value',path='/xxx/uuu',domain='.test.com')
s.cookies.update(c)?
總結
原文鏈接:https://blog.csdn.net/weixin_43258703/article/details/122349785
相關推薦
- 2023-01-15 使用SimpleITK讀取NII格式三維圖像及注意事項說明_python
- 2022-08-31 Postgresql數據庫character?varying和character的區別說明_Post
- 2022-05-17 Redis調用Lua腳本及使用場景快速掌握_Redis
- 2022-12-24 Docker中redis安裝及測試教程_docker
- 2022-12-07 【Chrome】瀏覽器控制臺設置成中文
- 2021-12-01 Android?NDK開發(C語言--聯合體與枚舉)_Android
- 2022-05-22 Python讀寫yaml文件_python
- 2022-04-20 Httprunner簡介、安裝及基本使用教程_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支