Проблема загрузки файла с использованием Python и Urllib2 - PullRequest
0 голосов
/ 25 апреля 2011
import os
import sys
import time
import base64
import hmac
import mimetypes
import urllib2
from hashlib import sha1
from poster.streaminghttp import register_openers

def read_data(file_object):
    while True:
        r = file_object.read(1 * 1024)
        print 'rrr',r
        if not r:
            print 'r'
            file_object.close()
            break
        yield r

def upload_file(filename, bucket):
    print 'start'
    length = os.stat(filename).st_size
    content_type = mimetypes.guess_type(filename)[0]
    date = time.strftime("%a, %d %b %Y %X GMT", time.gmtime())

print 'before'
register_openers()
print 'after'
input_file = open(filename, 'r')
print 'read mode'
data = read_data(input_file)
request = urllib2.Request(bucket, data=data)

request.add_header('Date', date)
request.add_header('Content-Type', content_type)
request.add_header('Content-Length', length)

request.get_method = lambda: 'PUT'
print 'before lamda'
urllib2.urlopen(request).read()

upload_file('C:\\test.pdf', "http://10.105.158.132:26938/DocLib1/ste.pdf")

приведенный выше код предназначен для потоковой передачи и загрузки данных. потоковая передача работает нормально. При загрузке код висит в следующем коде urllib2.urlopen (запрос) .read ()

Ответы [ 2 ]

0 голосов
/ 25 апреля 2011

Один аргумент showtopper может быть вашими аргументами при заполнении urllib2.Request

request = urllib2.Request(bucket, data=data)

Первый аргумент должен быть действительным URL. Из вашего общего кода не оказалось, что корзина была заполнена URL-адресом S3 для чего бы то ни было. Это может привести к сбою urlopen, так как он использует возвращаемое значение для этого вызова.

0 голосов
/ 25 апреля 2011

Используйте strace или сетевой анализатор, такой как Wireshark , для поиска проблемы.

...