国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Heim Backend-Entwicklung Python-Tutorial Python發(fā)送form-data請求及拼接form-data內容的方法

Python發(fā)送form-data請求及拼接form-data內容的方法

Jun 10, 2016 pm 03:05 PM
form-data python requests Bilden fragen

?網上關于使用python 的發(fā)送multipart/form-data的方法,多半是采用

ulrlib2 的模擬post方法,如下:

import urllib2

boundary='-------------------------7df3069603d6' 
data=[] 
data.append('--%s' % boundary) 
data.append('Content-Disposition: form-data; name="app_id"\r\n') 
data.append('xxxxxx') 
data.append('--%s' % boundary) 
data.append('Content-Disposition: form-data; name="version"\r\n') 
data.append('xxxxx') 
data.append('--%s' % boundary) 
data.append('Content-Disposition: form-data; name="platform"\r\n') 
data.append('xxxxx') 
data.append('--%s' % boundary) 
data.append('Content-Disposition: form-data; name="libzip"; filename="C:\Users\danwang3\Desktop\libmsc.zip"') 
data.append('Content-Type: application/octet-stream\r\n') 
 
fr=open('C:\Users\danwang3\Desktop\libmsc.zip') 
content=fr.read() 
data.append(content) 
print content 
fr.close() 
data.append('--%s--\r\n'%boundary) 
httpBody='\r\n'.join(data) 
 
print type(httpBody) 
print httpBody 
 
postDataUrl='http://xxxxxxxx' 
req=urllib2.Request(postDataUrl,data=httpBody) 

經過測試,使用上述方法發(fā)送一段二進制文件的時候,服務器報錯,數據有問題!

問題就出在 '\r\n'.join(data)的編碼,data內部擁有二進制數據,通過這種編碼,可能是把數據轉換為utf-8格式,當然有問題。

搜索了很多資料,查到可以使用requests庫提交multipart/form-data 格式的數據

一個multipart/form-data 的表單數據,在http里面抓包如下:

#Content-Disposition: form-data;name="app_id"


 123456

#-----------------------------7df23df2a0870

#Content-Disposition: form-data;name="version"

 

 2256

 -----------------------------7df23df2a0870

 Content-Disposition:form-data; name="platform"

 

 ios

 -----------------------------7df23df2a0870

 Content-Disposition: form-data;name="libzip";filename="C:\Users\danwang3\Desktop\libmsc.zip"

 Content-Type: application/x-zip-compressed

<二進制文件數據未顯示>

 ---------------------------7df23df2a0870—


上述數據在requests里面可以模擬為:

files={'app_id':(None,'123456'),
  'version':(None,'2256'),
  'platform':(None,'ios'),
  'libzip':('libmsc.zip',open('C:\Users\danwang3\Desktop\libmsc.zip','rb'),'application/x-zip-compressed')
 }

發(fā)送上述post請求,也就是簡單的

response=requests.post(url,files=files)

就這么簡單

在官方網站上,requests模擬一個表單數據的格式如下:

files = {'name': (, ,, )}

這一行模擬出來的post數據為:

Content-Disposition: form-data; name='name';filename=<filename>
Content-Type: <content type>
 
<file object>
--boundary

如果filename 和 content-Type不寫,那么響應模擬post的數據就不會有二者。

通常使用requests 不像使用urllib2那樣可以自動管理cookie,不過如果獲取到cookie

可以在requests請求里面一并將cookie發(fā)送出去

requests使用的cookie格式如下:

newCookie={}
newCookie['key1']='value1'
newCookie['key2]='value2'
newCookie['key3']='value3'


發(fā)送cookie可以使用:

response=requests.post(url,cookies=newCookie)

這樣就可以了

拼接form-data的post內容

#!\urs\bin\env python 
#encoding:utf-8    #設置編碼方式  
  
from http2 import http 
import urllib 
 
def ReadFileAsContent(filename): 
  #print filename 
  try: 
    with open(filename, 'rb') as f: 
      filecontent = f.read() 
  except Exception, e: 
    print 'The Error Message in ReadFileAsContent(): ' + e.message  
    return '' 
  return filecontent 
 
 
def get_content_type(filename): 
  import mimetypes 
  return mimetypes.guess_type(filename)[0] or 'application/octet-stream' 
 
def isfiledata(p_str):  
  import re 
   
  r_c = re.compile("^f'(.*)'$") 
  rert = r_c.search(str(p_str)) 
  #rert = re.search("^f'(.*)'$", p_str) 
  if rert: 
    return rert.group(1) 
  else: 
    return None 
   
def encode_multipart_formdata(fields): 
  ''''' 
      該函數用于拼接multipart/form-data類型的http請求中body部分的內容 
      返回拼接好的body內容及Content-Type的頭定義 
  ''' 
  import random 
  import os 
  BOUNDARY = '----------%s' % ''.join(random.sample('0123456789abcdef', 15)) 
  CRLF = '\r\n' 
  L = [] 
  for (key, value) in fields: 
    filepath = isfiledata(value) 
    if filepath: 
      L.append('--' + BOUNDARY) 
      L.append('Content-Disposition: form-data; name="%s"; filename="%s"' % (key, os.path.basename(filepath))) 
      L.append('Content-Type: %s' % get_content_type(filepath)) 
      L.append('') 
      L.append(ReadFileAsContent(filepath))  
    else: 
      L.append('--' + BOUNDARY) 
      L.append('Content-Disposition: form-data; name="%s"' % key) 
      L.append('') 
      L.append(value)  
  L.append('--' + BOUNDARY + '--') 
  L.append('') 
  body = CRLF.join(L) 
  content_type = 'multipart/form-data; boundary=%s' % BOUNDARY 
  return content_type, body 

其中需要注意的是文件數據的字典值,其格式為f'/path/to/file',具體調用的形式如下:

form_data = [('gShopID','489'),("addItems", r"f'D:\case3guomei.xml'"), ('validateString', '92c99a2a36f47c6aa2f0019caa0591d2')] 
form_data_re = encode_multipart_formdata(form_data) 
print form_data_re 

返回的內容是一個元組,第一個參數是請求頭中Content-Type的值,第二個是具體post的內容。然后使用httplib的post方法就可以發(fā)送了。

Erkl?rung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Hei?e KI -Werkzeuge

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?e Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

PHP-Tutorial
1502
276
Python verbinden sich mit SQL Server PyoDBC -Beispiel Python verbinden sich mit SQL Server PyoDBC -Beispiel Jul 30, 2025 am 02:53 AM

Installieren Sie PYODBC: Verwenden Sie den Befehl pipinstallpyoDBC, um die Bibliothek zu installieren. 2. SQLServer verbinden: Verwenden Sie die Verbindungszeichenfolge, die Treiber, Server, Datenbank, UID/PWD oder Trusted_Connection über die Methode Pyodbc.Connect () und die SQL -Authentifizierung bzw. der Windows -Authentifizierung unterstützen; 3. überprüfen Sie den installierten Treiber: Führen Sie Pyodbc.Drivers () aus und filtern Sie den Treibernamen mit 'SQLServer', um sicherzustellen, dass der richtige Treiberame wie 'ODBCDRIVER17 für SQLServer' verwendet wird. 4. Schlüsselparameter der Verbindungszeichenfolge

Python Pandas Schmelze Beispiel Python Pandas Schmelze Beispiel Jul 27, 2025 am 02:48 AM

Pandas.Melt () wird verwendet, um weite Formatdaten in ein langes Format umzuwandeln. Die Antwort besteht darin, neue Spaltennamen zu definieren, indem id_vars angegeben wird, die Identifikationsspalte beibehalten. 4.Value_name = 'Score' legt den neuen Spaltennamen des ursprünglichen Wertes fest und generiert schlie?lich drei Spalten, einschlie?lich Name, Betreff und Punktzahl.

Python Django bildet Beispiel Python Django bildet Beispiel Jul 27, 2025 am 02:50 AM

Definieren Sie zun?chst ein ContactForm -Formular mit Namen, Mailbox und Nachrichtenfeldern. 2. In der Ansicht wird die Einreichung von Formular durch die Beurteilung der Postanfrage bearbeitet, und nach der überprüfung wird Cleaned_data erhalten und die Antwort wird zurückgegeben, sonst wird das leere Formular gerendert. 3. In der Vorlage verwenden Sie {{{form.as_p}}, um das Feld zu rendern und {%csrf_token%} hinzuzufügen, um CSRF -Angriffe zu verhindern; 4. Konfigurieren Sie die URL -Routing auf Punkt / Kontakt / an die Ansicht contact_view; Verwenden Sie Modelform, um das Modell direkt zu verknüpfen, um die Datenspeicherung zu erreichen. DjangoForms implementiert eine integrierte Verarbeitung von Datenüberprüfung, HTML -Rendering und Fehleraufforderungen, die für die schnelle Entwicklung sicherer Formfunktionen geeignet sind.

Optimierung von Python für Speichervorg?nge Optimierung von Python für Speichervorg?nge Jul 28, 2025 am 03:22 AM

PythoncanbeoptimizedFormemory-BoundoperationsByreducingoverheadThroughGeneratoren, effiziente Datastrukturen und ManagingObjectLifetimes.First, UseGeneratorsinSteadofListStoprocesslargedatasetasetasematatime, Vermeidung von loloadingeNthertomemory.Secondatasetasetematatime, Choos

Was ist statistische Arbitrage in Kryptow?hrungen? Wie funktioniert statistische Arbitrage? Was ist statistische Arbitrage in Kryptow?hrungen? Wie funktioniert statistische Arbitrage? Jul 30, 2025 pm 09:12 PM

Die Einführung in statistische Arbitrage Statistical Arbitrage ist eine Handelsmethode, die auf der Grundlage mathematischer Modelle Preisfehlanpassungen auf dem Finanzmarkt erfasst. Die Kernphilosophie beruht auf der mittleren Regression, dh, dass die Verm?genspreise kurzfristig von langfristigen Trends abweichen, aber schlie?lich zu ihrem historischen Durchschnitt zurückkehren. H?ndler verwenden statistische Methoden, um die Korrelation zwischen Verm?genswerten zu analysieren und nach Portfolios zu suchen, die normalerweise synchron ver?ndern. Wenn das Preisverh?ltnis dieser Verm?genswerte ungew?hnlich abgewichen ist, ergeben sich Arbitrage -M?glichkeiten. Auf dem Kryptow?hrungsmarkt ist die statistische Arbitrage besonders weit verbreitet, haupts?chlich aufgrund der Ineffizienz und drastischen Marktschwankungen des Marktes selbst. Im Gegensatz zu den traditionellen Finanzm?rkten arbeiten Kryptow?hrungen rund um die Uhr und ihre Preise sind ?u?erst anf?llig für Verst??e gegen Nachrichten, Social -Media -Stimmung und technologische Upgrades. Diese konstante Preisschwankung schafft h?ufig Preisgestaltung und liefert Arbitrageure mit

Python Iter und n?chstes Beispiel Python Iter und n?chstes Beispiel Jul 29, 2025 am 02:20 AM

Iter () wird verwendet, um das Iteratorobjekt zu erhalten, und als n?chstes () wird das n?chste Element erhalten. 1. Verwenden Sie Iterator (), um iterable Objekte wie Listen in Iteratoren umzuwandeln. 2. Rufen Sie als n?chstes an () an, um Elemente nacheinander zu erhalten, und ausl?sen Sie die Ausnahme der Stopperation, wenn die Elemente ersch?pft sind. 3. Verwenden Sie als n?chstes (Iterator, Standard), um Ausnahmen zu vermeiden. 4. Benutzerdefinierte Iteratoren müssen die Methoden __iter __ () und __Next __ () implementieren, um die Iterationslogik zu kontrollieren; Die Verwendung von Standardwerten ist ein h?ufiger Weg zum sicheren Traversal, und der gesamte Mechanismus ist pr?gnant und praktisch.

Python Psycopg2 Connection Pool Beispiel Python Psycopg2 Connection Pool Beispiel Jul 28, 2025 am 03:01 AM

Verwenden Sie PSYCOPG2.POOL.SimpleconnectionPool, um Datenbankverbindungen effektiv zu verwalten und den Leistungsaufwand zu vermeiden, der durch die h?ufige Erstellung und Zerst?rung von Verbindungen verursacht wird. 1. Geben Sie beim Erstellen eines Verbindungspools die minimale und maximale Anzahl von Verbindungen und Datenbankverbindungsparametern an, um sicherzustellen, dass der Verbindungspool erfolgreich initialisiert wird. 2. Nehmen Sie die Verbindung über getConn () ab und verwenden Sie PutConn (), um die Verbindung nach Ausführung des Datenbankvorgangs zum Pool zurückzugeben. Conn.Close () st?ndig aufrufen ist verboten; 3. SimpleConnectionPool ist mit Thread-sicher und für Umgebungen mit mehreren Threaden geeignet. 4.. Es wird empfohlen, einen Kontextmanager in Kombination mit Context Manager zu implementieren, um sicherzustellen, dass die Verbindung korrekt zurückgegeben werden kann, wenn Ausnahmen festgestellt werden.

Bioinformatik mit Python Biopython Bioinformatik mit Python Biopython Jul 27, 2025 am 02:33 AM

Biopython ist eine wichtige Python -Bibliothek zur Verarbeitung biologischer Daten in Bioinformatik, die umfangreiche Funktionen zur Verbesserung der Entwicklungseffizienz bietet. Die Installationsmethode ist einfach. Sie k?nnen die Installation mit PipInstallbiopython vervollst?ndigen. Nach dem Importieren des Bio -Moduls k?nnen Sie schnell gemeinsame Sequenzformate wie Fasta -Dateien analysieren. SEQ -Objekte unterstützen die Manipulation von DNA-, RNA- und Proteinsequenzen wie Inversions -Komplementarit?t und Translation in Proteinsequenzen. über Bio.entrez k?nnen Sie auf die NCBI -Datenbank zugreifen und GenBank -Daten erhalten. Sie müssen jedoch Ihre E -Mail -Adresse einrichten. Darüber hinaus unterstützt Biopython eine paarweise Sequenzausrichtung und PDB -Datei Parsing, die für Strukturanalyseaufgaben geeignet ist.

See all articles