mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-08-04 20:40:14 +03:00
Merge d170595723
into 48b66ec2a2
This commit is contained in:
commit
e93a1d1f56
|
@ -10,7 +10,7 @@ from django.core.files.uploadhandler import StopFutureHandlers
|
||||||
from django.http import QueryDict
|
from django.http import QueryDict
|
||||||
from django.http.multipartparser import MultiPartParser as DjangoMultiPartParser
|
from django.http.multipartparser import MultiPartParser as DjangoMultiPartParser
|
||||||
from django.http.multipartparser import MultiPartParserError, parse_header, ChunkIter
|
from django.http.multipartparser import MultiPartParserError, parse_header, ChunkIter
|
||||||
from rest_framework.compat import etree, six, yaml, force_text
|
from rest_framework.compat import etree, six, yaml, force_text, urlparse
|
||||||
from rest_framework.exceptions import ParseError
|
from rest_framework.exceptions import ParseError
|
||||||
from rest_framework import renderers
|
from rest_framework import renderers
|
||||||
import json
|
import json
|
||||||
|
@ -289,6 +289,17 @@ class FileUploadParser(BaseParser):
|
||||||
try:
|
try:
|
||||||
meta = parser_context['request'].META
|
meta = parser_context['request'].META
|
||||||
disposition = parse_header(meta['HTTP_CONTENT_DISPOSITION'].encode('utf-8'))
|
disposition = parse_header(meta['HTTP_CONTENT_DISPOSITION'].encode('utf-8'))
|
||||||
return force_text(disposition[1]['filename'])
|
|
||||||
|
if 'filename*' in disposition[1]:
|
||||||
|
filename_encoded = force_text(disposition[1]['filename*'])
|
||||||
|
try:
|
||||||
|
charset, filename_encoded = filename_encoded.split('\'\'', 1)
|
||||||
|
filename = urlparse.unquote(filename_encoded)
|
||||||
|
except (ValueError, LookupError):
|
||||||
|
filename = force_text(disposition[1]['filename'])
|
||||||
|
else:
|
||||||
|
filename = force_text(disposition[1]['filename'])
|
||||||
|
|
||||||
|
return filename
|
||||||
except (AttributeError, KeyError):
|
except (AttributeError, KeyError):
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
#-*- coding: utf-8 -*-
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
from rest_framework.compat import StringIO
|
from rest_framework.compat import StringIO
|
||||||
from django import forms
|
from django import forms
|
||||||
|
@ -113,3 +115,23 @@ class TestFileUploadParser(TestCase):
|
||||||
parser = FileUploadParser()
|
parser = FileUploadParser()
|
||||||
filename = parser.get_filename(self.stream, None, self.parser_context)
|
filename = parser.get_filename(self.stream, None, self.parser_context)
|
||||||
self.assertEqual(filename, 'file.txt')
|
self.assertEqual(filename, 'file.txt')
|
||||||
|
|
||||||
|
def test_get_encoded_filename(self):
|
||||||
|
parser = FileUploadParser()
|
||||||
|
|
||||||
|
self.__replace_content_disposition('inline; filename*=utf-8\'\'ÀĥƦ.txt')
|
||||||
|
filename = parser.get_filename(self.stream, None, self.parser_context)
|
||||||
|
self.assertEqual(filename, 'ÀĥƦ.txt')
|
||||||
|
|
||||||
|
self.__replace_content_disposition('inline; filename=fallback.txt; filename*=utf-8\'\'ÀĥƦ.txt')
|
||||||
|
filename = parser.get_filename(self.stream, None, self.parser_context)
|
||||||
|
self.assertEqual(filename, 'ÀĥƦ.txt')
|
||||||
|
|
||||||
|
self.__replace_content_disposition('inline; filename=fallback.txt; filename*=utf-8--ÀĥƦ.txt')
|
||||||
|
filename = parser.get_filename(self.stream, None, self.parser_context)
|
||||||
|
self.assertEqual(filename, 'fallback.txt')
|
||||||
|
|
||||||
|
def __replace_content_disposition(self, disposition):
|
||||||
|
self.parser_context['request'].META['HTTP_CONTENT_DISPOSITION'] = disposition
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user