mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #333 and #440 -- Split DEFAULT_MIME_TYPE setting into DEFAULT_CONTENT_TYPE and DEFAULT_CHARSET. Thanks, Maniac.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@786 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -32,9 +32,11 @@ LANGUAGE_CODE = 'en-us' | |||||||
| # notifications and other various e-mails. | # notifications and other various e-mails. | ||||||
| MANAGERS = ADMINS | MANAGERS = ADMINS | ||||||
|  |  | ||||||
| # Default MIME type to use for all HttpResponse objects, if a MIME type | # Default content type and charset to use for all HttpResponse objects, if a | ||||||
| # isn't manually specified. This is directly used as the Content-Type header. | # MIME type isn't manually specified. These are used to construct the | ||||||
| DEFAULT_MIME_TYPE = 'text/html; charset=utf-8' | # Content-Type header. | ||||||
|  | DEFAULT_CONTENT_TYPE = 'text/html' | ||||||
|  | DEFAULT_CHARSET = 'utf-8' | ||||||
|  |  | ||||||
| # E-mail address that error messages come from. | # E-mail address that error messages come from. | ||||||
| SERVER_EMAIL = 'root@localhost' | SERVER_EMAIL = 'root@localhost' | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| from django.core import validators | from django.core import validators | ||||||
| from django.core.exceptions import PermissionDenied | from django.core.exceptions import PermissionDenied | ||||||
| from django.utils.html import escape | from django.utils.html import escape | ||||||
|  | from django.conf.settings import DEFAULT_CHARSET | ||||||
|  |  | ||||||
| FORM_FIELD_ID_PREFIX = 'id_' | FORM_FIELD_ID_PREFIX = 'id_' | ||||||
|  |  | ||||||
| @@ -221,7 +222,7 @@ class TextField(FormField): | |||||||
|         self.validator_list = [self.isValidLength, self.hasNoNewlines] + validator_list |         self.validator_list = [self.isValidLength, self.hasNoNewlines] + validator_list | ||||||
|  |  | ||||||
|     def isValidLength(self, data, form): |     def isValidLength(self, data, form): | ||||||
|         if data and self.maxlength and len(data) > self.maxlength: |         if data and self.maxlength and len(data.decode(DEFAULT_CHARSET)) > self.maxlength: | ||||||
|             raise validators.ValidationError, "Ensure your text is less than %s characters." % self.maxlength |             raise validators.ValidationError, "Ensure your text is less than %s characters." % self.maxlength | ||||||
|  |  | ||||||
|     def hasNoNewlines(self, data, form): |     def hasNoNewlines(self, data, form): | ||||||
| @@ -235,7 +236,7 @@ class TextField(FormField): | |||||||
|         if self.maxlength: |         if self.maxlength: | ||||||
|             maxlength = 'maxlength="%s" ' % self.maxlength |             maxlength = 'maxlength="%s" ' % self.maxlength | ||||||
|         if isinstance(data, unicode): |         if isinstance(data, unicode): | ||||||
|             data = data.encode('utf-8') |             data = data.encode(DEFAULT_CHARSET) | ||||||
|         return '<input type="text" id="%s" class="v%s%s" name="%s" size="%s" value="%s" %s/>' % \ |         return '<input type="text" id="%s" class="v%s%s" name="%s" size="%s" value="%s" %s/>' % \ | ||||||
|             (FORM_FIELD_ID_PREFIX + self.field_name, self.__class__.__name__, self.is_required and ' required' or '', |             (FORM_FIELD_ID_PREFIX + self.field_name, self.__class__.__name__, self.is_required and ' required' or '', | ||||||
|             self.field_name, self.length, escape(data), maxlength) |             self.field_name, self.length, escape(data), maxlength) | ||||||
| @@ -264,7 +265,7 @@ class LargeTextField(TextField): | |||||||
|         if data is None: |         if data is None: | ||||||
|             data = '' |             data = '' | ||||||
|         if isinstance(data, unicode): |         if isinstance(data, unicode): | ||||||
|             data = data.encode('utf-8') |             data = data.encode(DEFAULT_CHARSET) | ||||||
|         return '<textarea id="%s" class="v%s%s" name="%s" rows="%s" cols="%s">%s</textarea>' % \ |         return '<textarea id="%s" class="v%s%s" name="%s" rows="%s" cols="%s">%s</textarea>' % \ | ||||||
|             (FORM_FIELD_ID_PREFIX + self.field_name, self.__class__.__name__, self.is_required and ' required' or '', |             (FORM_FIELD_ID_PREFIX + self.field_name, self.__class__.__name__, self.is_required and ' required' or '', | ||||||
|             self.field_name, self.rows, self.cols, escape(data)) |             self.field_name, self.rows, self.cols, escape(data)) | ||||||
|   | |||||||
| @@ -150,14 +150,15 @@ class ModPythonHandler(BaseHandler): | |||||||
|  |  | ||||||
| def populate_apache_request(http_response, mod_python_req): | def populate_apache_request(http_response, mod_python_req): | ||||||
|     "Populates the mod_python request object with an HttpResponse" |     "Populates the mod_python request object with an HttpResponse" | ||||||
|     mod_python_req.content_type = http_response['Content-Type'] or httpwrappers.DEFAULT_MIME_TYPE |     from django.conf import settings | ||||||
|  |     mod_python_req.content_type = http_response['Content-Type'] | ||||||
|     for key, value in http_response.headers.items(): |     for key, value in http_response.headers.items(): | ||||||
|         if key != 'Content-Type': |         if key != 'Content-Type': | ||||||
|             mod_python_req.headers_out[key] = value |             mod_python_req.headers_out[key] = value | ||||||
|     for c in http_response.cookies.values(): |     for c in http_response.cookies.values(): | ||||||
|         mod_python_req.headers_out.add('Set-Cookie', c.output(header='')) |         mod_python_req.headers_out.add('Set-Cookie', c.output(header='')) | ||||||
|     mod_python_req.status = http_response.status_code |     mod_python_req.status = http_response.status_code | ||||||
|     mod_python_req.write(http_response.get_content_as_string('utf-8')) |     mod_python_req.write(http_response.get_content_as_string(settings.DEFAULT_CHARSET)) | ||||||
|  |  | ||||||
| def handler(req): | def handler(req): | ||||||
|     # mod_python hooks into this function. |     # mod_python hooks into this function. | ||||||
|   | |||||||
| @@ -167,6 +167,6 @@ class WSGIHandler(BaseHandler): | |||||||
|         response_headers = response.headers.items() |         response_headers = response.headers.items() | ||||||
|         for c in response.cookies.values(): |         for c in response.cookies.values(): | ||||||
|             response_headers.append(('Set-Cookie', c.output(header=''))) |             response_headers.append(('Set-Cookie', c.output(header=''))) | ||||||
|         output = [response.get_content_as_string('utf-8')] |         output = [response.get_content_as_string(settings.DEFAULT_CHARSET)] | ||||||
|         start_response(status, response_headers) |         start_response(status, response_headers) | ||||||
|         return output |         return output | ||||||
|   | |||||||
| @@ -55,6 +55,7 @@ times with multiple contexts) | |||||||
| '\n<html>\n\n</html>\n' | '\n<html>\n\n</html>\n' | ||||||
| """ | """ | ||||||
| import re | import re | ||||||
|  | from django.conf.settings import DEFAULT_CHARSET | ||||||
|  |  | ||||||
| __all__ = ('Template','Context','compile_string') | __all__ = ('Template','Context','compile_string') | ||||||
|  |  | ||||||
| @@ -474,7 +475,7 @@ class VariableNode(Node): | |||||||
|         if not isinstance(output, basestring): |         if not isinstance(output, basestring): | ||||||
|             output = str(output) |             output = str(output) | ||||||
|         elif isinstance(output, unicode): |         elif isinstance(output, unicode): | ||||||
|             output = output.encode('utf-8') |             output = output.encode(DEFAULT_CHARSET) | ||||||
|         return output |         return output | ||||||
|  |  | ||||||
| def register_tag(token_command, callback_function): | def register_tag(token_command, callback_function): | ||||||
|   | |||||||
| @@ -76,7 +76,7 @@ class CacheMiddleware: | |||||||
|         Sets the cache, if needed. |         Sets the cache, if needed. | ||||||
|         """ |         """ | ||||||
|         if request._cache_middleware_set_cache: |         if request._cache_middleware_set_cache: | ||||||
|             content = response.get_content_as_string('utf-8') |             content = response.get_content_as_string(settings.DEFAULT_CHARSET) | ||||||
|             if request._cache_middleware_accepts_gzip: |             if request._cache_middleware_accepts_gzip: | ||||||
|                 content = compress_string(content) |                 content = compress_string(content) | ||||||
|                 response.content = content |                 response.content = content | ||||||
|   | |||||||
| @@ -76,7 +76,7 @@ class CommonMiddleware: | |||||||
|  |  | ||||||
|         # Use ETags, if requested. |         # Use ETags, if requested. | ||||||
|         if settings.USE_ETAGS: |         if settings.USE_ETAGS: | ||||||
|             etag = md5.new(response.get_content_as_string('utf-8')).hexdigest() |             etag = md5.new(response.get_content_as_string(settings.DEFAULT_CHARSET)).hexdigest() | ||||||
|             if request.META.get('HTTP_IF_NONE_MATCH') == etag: |             if request.META.get('HTTP_IF_NONE_MATCH') == etag: | ||||||
|                 response = httpwrappers.HttpResponseNotModified() |                 response = httpwrappers.HttpResponseNotModified() | ||||||
|             else: |             else: | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| from Cookie import SimpleCookie | from Cookie import SimpleCookie | ||||||
| from pprint import pformat | from pprint import pformat | ||||||
| from urllib import urlencode | from urllib import urlencode | ||||||
| import datastructures | from django.utils import datastructures | ||||||
|  |  | ||||||
| class HttpRequest(object): # needs to be new-style class because subclasses define "property"s | class HttpRequest(object): # needs to be new-style class because subclasses define "property"s | ||||||
|     "A basic HTTP request" |     "A basic HTTP request" | ||||||
| @@ -139,8 +139,8 @@ class HttpResponse: | |||||||
|     "A basic HTTP response, with content and dictionary-accessed headers" |     "A basic HTTP response, with content and dictionary-accessed headers" | ||||||
|     def __init__(self, content='', mimetype=None): |     def __init__(self, content='', mimetype=None): | ||||||
|         if not mimetype: |         if not mimetype: | ||||||
|             from django.conf.settings import DEFAULT_MIME_TYPE |             from django.conf.settings import DEFAULT_CONTENT_TYPE, DEFAULT_CHARSET | ||||||
|             mimetype = DEFAULT_MIME_TYPE |             mimetype = "%s; charset=%s" % (DEFAULT_CONTENT_TYPE, DEFAULT_CHARSET) | ||||||
|         self.content = content |         self.content = content | ||||||
|         self.headers = {'Content-Type':mimetype} |         self.headers = {'Content-Type':mimetype} | ||||||
|         self.cookies = SimpleCookie() |         self.cookies = SimpleCookie() | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| from django.core.cache import cache | from django.core.cache import cache | ||||||
| from django.utils.httpwrappers import HttpResponseNotModified | from django.utils.httpwrappers import HttpResponseNotModified | ||||||
| from django.utils.text import compress_string | from django.utils.text import compress_string | ||||||
|  | from django.conf.settings import DEFAULT_CHARSET | ||||||
| import datetime, md5 | import datetime, md5 | ||||||
|  |  | ||||||
| def cache_page(view_func, cache_timeout, key_prefix=''): | def cache_page(view_func, cache_timeout, key_prefix=''): | ||||||
| @@ -25,7 +26,7 @@ def cache_page(view_func, cache_timeout, key_prefix=''): | |||||||
|         response = cache.get(cache_key, None) |         response = cache.get(cache_key, None) | ||||||
|         if response is None: |         if response is None: | ||||||
|             response = view_func(request, *args, **kwargs) |             response = view_func(request, *args, **kwargs) | ||||||
|             content = response.get_content_as_string('utf-8') |             content = response.get_content_as_string(DEFAULT_CHARSET) | ||||||
|             if accepts_gzip: |             if accepts_gzip: | ||||||
|                 content = compress_string(content) |                 content = compress_string(content) | ||||||
|                 response.content = content |                 response.content = content | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user