Sto provando a scrivere un codice Python che può creare richieste HTTP multi-mime nel client e quindi interpretare in modo appropriato sul server. Ho, credo, in parte riuscito sul lato client con questo:Creare e analizzare richieste HTTP multipart in Python
from email.mime.multipart import MIMEMultipart, MIMEBase
import httplib
h1 = httplib.HTTPConnection('localhost:8080')
msg = MIMEMultipart()
fp = open('myfile.zip', 'rb')
base = MIMEBase("application", "octet-stream")
base.set_payload(fp.read())
msg.attach(base)
h1.request("POST", "http://localhost:8080/server", msg.as_string())
L'unico problema è che la biblioteca di posta elettronica include anche il Content-Type e le intestazioni MIME-Version, e non sono sicuro come stanno andando essere correlato alle intestazioni HTTP inclusi da httplib:
Content-Type: multipart/mixed; boundary="===============2050792481=="
MIME-Version: 1.0
--===============2050792481==
Content-Type: application/octet-stream
MIME-Version: 1.0
questo può essere il motivo che, quando la richiesta viene ricevuta da mia applicazione web.py, ottengo solo un messaggio di errore. Il gestore web.py POST:
class MultipartServer:
def POST(self, collection):
print web.input()
Getta questo errore:
Traceback (most recent call last):
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/application.py", line 242, in process
return self.handle()
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/application.py", line 233, in handle
return self._delegate(fn, self.fvars, args)
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/application.py", line 415, in _delegate
return handle_class(cls)
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/application.py", line 390, in handle_class
return tocall(*args)
File "/home/richard/Development/server/webservice.py", line 31, in POST
print web.input()
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/webapi.py", line 279, in input
return storify(out, *requireds, **defaults)
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/utils.py", line 150, in storify
value = getvalue(value)
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/utils.py", line 139, in getvalue
return unicodify(x)
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/utils.py", line 130, in unicodify
if _unicode and isinstance(s, str): return safeunicode(s)
File "/usr/local/lib/python2.6/dist-packages/web.py-0.34-py2.6.egg/web/utils.py", line 326, in safeunicode
return obj.decode(encoding)
File "/usr/lib/python2.6/encodings/utf_8.py", line 16, in decode
return codecs.utf_8_decode(input, errors, True)
UnicodeDecodeError: 'utf8' codec can't decode bytes in position 137-138: invalid data
La mia linea di codice è rappresentato dalla linea di errore di circa metà strada verso il basso:
File "/home/richard/Development/server/webservice.py", line 31, in POST
print web.input()
Sta arrivando lungo , ma non sono sicuro di dove andare da qui. Si tratta di un problema con il mio codice cliente o con una limitazione di web.py (forse non è in grado di supportare richieste multipart)? Eventuali suggerimenti o suggerimenti di librerie di codici alternativi sarebbero stati ricevuti con gratitudine.
EDIT
L'errore precedente è stato causato dai dati non vengono automaticamente Base64 codificati. Aggiunta
encoders.encode_base64(base)
Elimina questo errore e ora il problema è chiaro. richiesta HTTP non viene interpretata correttamente nel server, presumibilmente perché la libreria e-mail è compreso che dovrebbero essere le intestazioni HTTP nel corpo invece:
<Storage {'Content-Type: multipart/mixed': u'',
' boundary': u'"===============1342637378=="\n'
'MIME-Version: 1.0\n\n--===============1342637378==\n'
'Content-Type: application/octet-stream\n'
'MIME-Version: 1.0\n'
'Content-Transfer-Encoding: base64\n'
'\n0fINCs PBk1jAAAAAAAAA.... etc
Quindi qualcosa non è proprio lì.
Grazie
Richard
cosa diavolo è una richiesta multipart http? Questo concetto è effettivamente usato? – SingleNegationElimination
@TokenMacGuy - sì. sì. –