佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > python通過(guò)http上傳文件思路詳解

python通過(guò)http上傳文件思路詳解

熱門標(biāo)簽:鐵路電話系統(tǒng) 呼叫中心市場(chǎng)需求 檢查注冊(cè)表項(xiàng) 銀行業(yè)務(wù) 網(wǎng)站文章發(fā)布 服務(wù)器配置 美圖手機(jī) 智能手機(jī)

這里主要是解決multipart/form-data這種格式的文件上傳,基本現(xiàn)在http協(xié)議上傳文件基本上都是通過(guò)這種格式上傳

1 思路

一般情況下,如果我們往一個(gè)地址上傳文件,則必須要登陸,登陸成功后,拿到cookies,然后在上傳文件的請(qǐng)求攜帶這個(gè)cookies。

然后我們就需要通過(guò)瀏覽器在網(wǎng)站上傳文件,這個(gè)時(shí)候我們需要打開瀏覽器的開發(fā)者工具或者fiddler,然后按照抓到包組裝我們的上傳文件的post請(qǐng)求

大家把握一個(gè)原則就是:在post請(qǐng)求中,用files參數(shù)來(lái)接受文件對(duì)象相關(guān)的參數(shù),通過(guò)data/json參數(shù)接受post請(qǐng)求體的其他參數(shù)即可。

2 實(shí)現(xiàn)

2.1 登陸網(wǎng)站

使用requests.session()對(duì)象登陸網(wǎng)站,這里主要為了方便,下次直接用這個(gè)對(duì)象發(fā)送post上傳文件的請(qǐng)求即可,不需要我們?cè)谡?qǐng)求體中添加cookies

查找登錄的URL

查找請(qǐng)求頭

查找登錄參數(shù)

代碼如下: 

import requests
 
s = requests.session()
 
res1 = s.post(
    url="http://127.0.0.1:5000/login",
    headers={
        'Host': '127.0.0.1:5000',
        'Connection': 'keep-alive',
        'Content-Length': '28',
        'Cache-Control': 'max-age=0',
        'sec-ch-ua': '" Not A;Brand";v="99", "Chromium";v="90", "Google Chrome";v="90"',
        'sec-ch-ua-mobile': '?0',
        'Upgrade-Insecure-Requests': '1',
        'Origin': 'http://127.0.0.1:5000',
        'Content-Type': 'application/x-www-form-urlencoded',
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36',
        'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
        'Sec-Fetch-Site': 'same-origin',
        'Sec-Fetch-Mode': 'navigate',
        'Sec-Fetch-User': '?1',
        'Sec-Fetch-Dest': 'document',
        'Referer': 'http://127.0.0.1:5000/login',
        'Accept-Encoding': 'gzip, deflate, br',
        'Accept-Language': 'zh-CN,zh;q=0.9'
    },
    data={
        "account": "admin",
        "password": "admin"
    }
)

2.2 手動(dòng)上傳文件,分析http請(qǐng)求的參數(shù)

由于谷歌瀏覽器無(wú)法查看上傳文件時(shí)http請(qǐng)求的參數(shù),故使用fiddler來(lái)進(jìn)行抓包

抓包情況如下:

說(shuō)明:

上圖中第一個(gè)紅框中參數(shù)后面全是亂碼,這里就是我們上傳的文件二進(jìn)制格式的表現(xiàn),這里的數(shù)據(jù)就是通過(guò)files參數(shù)接收 

第二個(gè)紅框中name的值就是k,比如cid就是k值,下一行的值 7 就是v,這里的參數(shù)就是要通過(guò)data參數(shù)接收

上面是http請(qǐng)求的raw格式,我們一般會(huì)看webForms格式的http請(qǐng)求

 分

析完成后,可以看下代碼:

res2 = s.post(
    url="http://127.0.0.1:5000/upload",
    headers={
        'Host': '127.0.0.1:5000',
        'Connection': 'keep-alive',
        'Content-Length': '28',
        'Cache-Control': 'max-age=0',
        'sec-ch-ua': '" Not A;Brand";v="99", "Chromium";v="90", "Google Chrome";v="90"',
        'sec-ch-ua-mobile': '?0',
        'Upgrade-Insecure-Requests': '1',
        'Origin': 'http://127.0.0.1:5000',
        # 'Content-Type': 'application/x-www-form-urlencoded',
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36',
        'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
        'Sec-Fetch-Site': 'same-origin',
        'Sec-Fetch-Mode': 'navigate',
        'Sec-Fetch-User': '?1',
        'Sec-Fetch-Dest': 'document',
        'Referer': 'http://127.0.0.1:5000/login',
        'Accept-Encoding': 'gzip, deflate, br',
        'Accept-Language': 'zh-CN,zh;q=0.9'
    },
    files={
        "filename_list": open("./test", "rb"),
        "Content-Type": "text/plain",
        "Content-Disposition": "form-data",
        "filename": "test"
    },
 
    data={
        "cid": "7"
    }
)

3 三個(gè)關(guān)鍵點(diǎn)

3.1 data參數(shù)

注意看k值和抓包中的對(duì)比

3.2 files參數(shù)

這里很關(guān)鍵,這里就是我們上傳的文件對(duì)象了。filename_list 這個(gè)參數(shù)就代表文件文件對(duì)象,filename 這個(gè)值一般就是上傳后的文件的名稱(可以不寫)

3.3 content-type參數(shù)

如果我們通過(guò)form-data的方式上傳文件,我們組裝post請(qǐng)求的時(shí)候,headers這個(gè)參數(shù)中一定不能要包括這個(gè)值,由requests庫(kù)幫添加這個(gè)元素

如果我們自作聰明,會(huì)導(dǎo)致上傳失敗的,這里非常重要!?。?/strong>

大家可以看到,我在代碼中沒(méi)有傳遞content-type這個(gè)參數(shù),但是抓包是有這個(gè)參數(shù)的,所以這個(gè)參數(shù)我們一定不能加

 實(shí)際抓包有這個(gè)參數(shù)

實(shí)際上傳抓包驗(yàn)證即可,和瀏覽器上傳略有不同,但是不影響上傳 

到此這篇關(guān)于python通過(guò)http上傳文件的文章就介紹到這了,更多相關(guān)python上傳文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python request post上傳文件常見要點(diǎn)
  • python實(shí)現(xiàn)上傳文件到linux指定目錄的方法
  • Python SELENIUM上傳文件或圖片實(shí)現(xiàn)過(guò)程
  • Python模擬瀏覽器上傳文件腳本的方法(Multipart/form-data格式)
  • Python實(shí)現(xiàn)FTP上傳文件或文件夾實(shí)例(遞歸)
  • Python ftp上傳文件
  • Python用GET方法上傳文件
  • Python使用百度API上傳文件到百度網(wǎng)盤代碼分享
  • python使用paramiko模塊實(shí)現(xiàn)ssh遠(yuǎn)程登陸上傳文件并執(zhí)行

標(biāo)簽:上海 滄州 樂(lè)山 沈陽(yáng) 新疆 紅河 長(zhǎng)治 河南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python通過(guò)http上傳文件思路詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    博湖县| 武汉市| 盐亭县| 青田县| 麦盖提县| 霸州市| 天祝| 明星| 左权县| 育儿| 贵港市| 忻州市| 南投市| 城口县| 武安市| 卢氏县| 姜堰市| 新余市| 鹤山市| 鄢陵县| 车险| 隆子县| 怀仁县| 保亭| 游戏| 喜德县| 长岛县| 抚顺县| 乌兰察布市| 库伦旗| 容城县| 临高县| 长兴县| 志丹县| 冕宁县| 杭锦后旗| 沽源县| 方山县| 嵊泗县| 龙州县| 拉萨市|