Fixed #27948 -- Removed incorrect unquote() in static serving views.
This commit is contained in:
parent
6b4f018b2b
commit
b536dcf656
|
@ -5,7 +5,6 @@ development, and SHOULD NOT be used in a production setting.
|
||||||
"""
|
"""
|
||||||
import os
|
import os
|
||||||
import posixpath
|
import posixpath
|
||||||
from urllib.parse import unquote
|
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.contrib.staticfiles import finders
|
from django.contrib.staticfiles import finders
|
||||||
|
@ -30,7 +29,7 @@ def serve(request, path, insecure=False, **kwargs):
|
||||||
"""
|
"""
|
||||||
if not settings.DEBUG and not insecure:
|
if not settings.DEBUG and not insecure:
|
||||||
raise Http404
|
raise Http404
|
||||||
normalized_path = posixpath.normpath(unquote(path)).lstrip('/')
|
normalized_path = posixpath.normpath(path).lstrip('/')
|
||||||
absolute_path = finders.find(normalized_path)
|
absolute_path = finders.find(normalized_path)
|
||||||
if not absolute_path:
|
if not absolute_path:
|
||||||
if path.endswith('/') or path == '':
|
if path.endswith('/') or path == '':
|
||||||
|
|
|
@ -7,7 +7,6 @@ import os
|
||||||
import posixpath
|
import posixpath
|
||||||
import re
|
import re
|
||||||
import stat
|
import stat
|
||||||
from urllib.parse import unquote
|
|
||||||
|
|
||||||
from django.http import (
|
from django.http import (
|
||||||
FileResponse, Http404, HttpResponse, HttpResponseNotModified,
|
FileResponse, Http404, HttpResponse, HttpResponseNotModified,
|
||||||
|
@ -34,7 +33,7 @@ def serve(request, path, document_root=None, show_indexes=False):
|
||||||
but if you'd like to override it, you can create a template called
|
but if you'd like to override it, you can create a template called
|
||||||
``static/directory_index.html``.
|
``static/directory_index.html``.
|
||||||
"""
|
"""
|
||||||
path = posixpath.normpath(unquote(path))
|
path = posixpath.normpath(path)
|
||||||
path = path.lstrip('/')
|
path = path.lstrip('/')
|
||||||
newpath = ''
|
newpath = ''
|
||||||
for part in path.split('/'):
|
for part in path.split('/'):
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
%2F content
|
|
@ -128,3 +128,6 @@ class TestDefaults:
|
||||||
Can find a file with capital letters.
|
Can find a file with capital letters.
|
||||||
"""
|
"""
|
||||||
self.assertFileContains('test/camelCase.txt', 'camelCase')
|
self.assertFileContains('test/camelCase.txt', 'camelCase')
|
||||||
|
|
||||||
|
def test_filename_with_percent_sign(self):
|
||||||
|
self.assertFileContains('test/%2F.txt', '%2F content')
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import posixpath
|
import posixpath
|
||||||
|
from urllib.parse import quote
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
from django.test import override_settings
|
from django.test import override_settings
|
||||||
|
@ -12,8 +13,7 @@ class TestServeStatic(StaticFilesTestCase):
|
||||||
Test static asset serving view.
|
Test static asset serving view.
|
||||||
"""
|
"""
|
||||||
def _response(self, filepath):
|
def _response(self, filepath):
|
||||||
return self.client.get(
|
return self.client.get(quote(posixpath.join(settings.STATIC_URL, filepath)))
|
||||||
posixpath.join(settings.STATIC_URL, filepath))
|
|
||||||
|
|
||||||
def assertFileContains(self, filepath, text):
|
def assertFileContains(self, filepath, text):
|
||||||
self.assertContains(self._response(filepath), text)
|
self.assertContains(self._response(filepath), text)
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
%2F content
|
|
@ -1,6 +1,7 @@
|
||||||
import mimetypes
|
import mimetypes
|
||||||
import unittest
|
import unittest
|
||||||
from os import path
|
from os import path
|
||||||
|
from urllib.parse import quote
|
||||||
|
|
||||||
from django.conf.urls.static import static
|
from django.conf.urls.static import static
|
||||||
from django.core.exceptions import ImproperlyConfigured
|
from django.core.exceptions import ImproperlyConfigured
|
||||||
|
@ -21,9 +22,9 @@ class StaticTests(SimpleTestCase):
|
||||||
|
|
||||||
def test_serve(self):
|
def test_serve(self):
|
||||||
"The static view can serve static media"
|
"The static view can serve static media"
|
||||||
media_files = ['file.txt', 'file.txt.gz']
|
media_files = ['file.txt', 'file.txt.gz', '%2F.txt']
|
||||||
for filename in media_files:
|
for filename in media_files:
|
||||||
response = self.client.get('/%s/%s' % (self.prefix, filename))
|
response = self.client.get('/%s/%s' % (self.prefix, quote(filename)))
|
||||||
response_content = b''.join(response)
|
response_content = b''.join(response)
|
||||||
file_path = path.join(media_dir, filename)
|
file_path = path.join(media_dir, filename)
|
||||||
with open(file_path, 'rb') as fp:
|
with open(file_path, 'rb') as fp:
|
||||||
|
|
Loading…
Reference in New Issue