首先是前端要发送上传的文件。
后端接收文件的时候用:
单个数据的获取方法: v1=request.POST.get('file') 这样获得的是单个文件 多个数据的获取方法: v2=request.POST.getlist('files') 这样获得的是一个dict
文件需要保存的话:(代码是多个文件的保存)
if not content:
return HttpResponse("没有上传内容")
uploadfilepath = "./Upload"
if not os.path.exists(uploadfilepath):
os.makedirs(uploadfilepath)
for each in content:
position = os.path.join(uploadfilepath, each.name)
print(position)
storage = open(position, 'wb')
for chunk in each.chunks():
storage.write(chunk)
storage.close()
- 上传的文件属性是:UploadedFile
UploadedFile是类文件对象,具有以下方法和属性:
1. UploadedFile.read()
读取整个上传文件的数据,文件较大时慎用。
2. UploadedFile.multiple_chunks(chunk_size=None)
判断文件是否足够大,一般为2.5M
3. UploadedFile.chunks(chunk_size=None)
返回一个生成器对象,当multiple_chunks()为True时应该使用这个方法来代替read().
4. UploadedFile.name
上传文件的name。
5. UploadedFile.size
上传文件的大小。
6. UploadedFile.content_type
上传文件时的content_type报头,例如(e.g. text/plain or application/pdf).
7. UpladedFile.charset
编码