4

我正在使用一个简单的 REST 客户端进行测试。发送一个简单的 JPEG,尝试了以下内容类型: 内容类型:image/jpeg 内容类型:multipart/form-data

另请注意,关闭 csrftoken 身份验证以允许外部 3rd 方 REST 连接。

(图片通过rest客户端附加)检查wireshark并根据上述参数设置数据包。

Django - 请求对象有几个变量:request.body request.FILES

在 Django 服务器接收到 POST 后,请求对象总是将所有数据/有效负载存储到 request.body 中。图像或任何附加文件不应该进入 request.FILES 吗?是否在内容类型或 POST 上设置不正确。

非常简单的代码。只是试图打印到日志中。post 中的所有对象都将继续访问 request.body

def testPost(request):
     print request.body
     print request.FILES
     return HttpResponse()

Wireshark 数据包:

Hypertext Transfer Protocol
POST /testPost/ HTTP/1.1\r\n
Host: MYURL.com:8000\r\n
Connection: keep-alive\r\n
Content-Length: 8318\r\n
Origin: chrome-extension://aejoelaoggembcahagimdiliamlcdmfm\r\n
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36\r\n
Content-Type: image/jpeg\r\n
Accept: */*\r\n
Accept-Encoding: gzip,deflate,sdch\r\n
Accept-Language: en-US,en;q=0.8,zh-CN;q=0.6,zh;q=0.4\r\n
Cookie: ******; csrftoken=**********\r\n
\r\n
[Full request URI: http://MYURL.com:8000/testPost/]
[HTTP request 1/1]

JPEG 文件交换格式

4

1 回答 1

3

以下是我处理文件上传的方式:在这种情况下恰好是图像。我与之斗争了一段时间的问题之一是 request.FILES 可能带有多个键,而我一直想要最后一个。

注意:request.FILES 仅在以下情况下包含数据:

  1. 请求是一个 POST
  2. 请求具有属性'enctype="multipart/form-data"'

有关更多详细信息,请参阅Django 文件上传文档。

模型:首先有一个带有 ImageField 的模型:models.py

photos_dir = settings.MEDIA_ROOT + "/photos" + "/%Y/%m/%d/"

class Photo(models.Model):
   image    = models.ImageField(upload_to=photos_dir, null=True, blank=True, default=None)
   filename = models.CharField(max_length=60, blank=True, null=True)

视图:在views.py 中处理帖子:

from django.core.files.images import ImageFile

def upload_image( request ):

   file_key=None
   for file_key in sorted(request.FILES):
      pass

   wrapped_file = ImageFile(request.FILES[file_key])
   filename = wrapped_file.name

   # new photo table-row 
   photo = Photo()
   photo.filename = filename
   photo.image = request.FILES[file_key]

   try:
      photo.save()
   except OSError:
      print "Deal with this situation"

   # do your stuff here.
   return HttpResponse("boo", "text/html");

独立海报:一些 python 代码来激发你的 django 视图。

参考:我实际上使用了这个库:poster.encode来“刺激数据”到我的 django view.py

from poster.streaminghttp import register_openers
from poster.encode import multipart_encode
import urllib2

server = "http://localhost/"
headers = {}

# Register the streaming http handlers with urllib2
register_openers()

img="path/to/image/image.png"

data = {'media' : open( img ),
        'additionalattr': 111,
}
datagen, headers = multipart_encode(data)

headers['Connection']='keep-alive'
request = urllib2.Request('%s/upload_image/' % ( server ), datagen, headers)

print urllib2.urlopen(request).read() 
于 2014-01-05T08:04:30.900 回答