mam*_*mcx 3 django localization django-middleware
我想以英语和西班牙语部署网站,并检测用户浏览器语言并重定向到正确的区域设置站点.
我的网站是www.elmalabarista.com
我安装了django-localeurl,但我发现没有正确检测到该语言.
这是我的中间件:
MIDDLEWARE_CLASSES = (
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.locale.LocaleMiddleware',
'multilingual.middleware.DefaultLanguageMiddleware',
'middleware.feedburner.FeedburnerMiddleware',
'lib.threadlocals.ThreadLocalsMiddleware',
'middleware.url.UrlMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'maintenancemode.middleware.MaintenanceModeMiddleware',
'middleware.redirect.RedirectMiddleware',
'openidconsumer.middleware.OpenIDMiddleware',
'django.middleware.doc.XViewMiddleware',
'middleware.ajax_errors.AjaxMiddleware',
'pingback.middleware.PingbackMiddleware',
'localeurl.middleware.LocaleURLMiddleware',
'multilingual.flatpages.middleware.FlatpageFallbackMiddleware',
'django.middleware.common.CommonMiddleware',
)
Run Code Online (Sandbox Code Playgroud)
但是,尽管我的操作系统和浏览器设置是西班牙语,但该网站总是到达美国.
LANGUAGES = (
('en', ugettext('English')),
('es', ugettext('Spanish')),
)
DEFAULT_LANGUAGE = 1
Run Code Online (Sandbox Code Playgroud)
然后,我破解了locale-url的中间件并执行此操作:
def process_request(self, request):
locale, path = self.split_locale_from_request(request)
if request.META.has_key('HTTP_ACCEPT_LANGUAGE'):
locale = utils.supported_language(request.META['HTTP_ACCEPT_LANGUAGE'].split(',')[0])
locale_path = utils.locale_path(path, locale)
if locale_path != request.path_info:
if request.META.get("QUERY_STRING", ""):
locale_path = "%s?%s" % (locale_path,
request.META['QUERY_STRING'])
return HttpResponseRedirect(locale_path)
request.path_info = path
if not locale:
locale = settings.LANGUAGE_CODE
translation.activate(locale)
request.LANGUAGE_CODE = translation.get_language()
Run Code Online (Sandbox Code Playgroud)
但是,这可以检测到语言,但将"en"URL重定向到"es".所以不可能用英语导航.
更新:这是最终代码(在Carl Meyer的输入之后)修复了"/"的情况:
def process_request(self, request):
locale, path = self.split_locale_from_request(request)
if (not locale) or (locale==''):
if request.META.has_key('HTTP_ACCEPT_LANGUAGE'):
locale = utils.supported_language(request.META['HTTP_ACCEPT_LANGUAGE'].split(',')[0])
else:
locale = settings.LANGUAGE_CODE
locale_path = utils.locale_path(path, locale)
if locale_path != request.path_info:
if request.META.get("QUERY_STRING", ""):
locale_path = "%s?%s" % (locale_path, request.META['QUERY_STRING'])
return HttpResponseRedirect(locale_path)
request.path_info = path
translation.activate(locale)
request.LANGUAGE_CODE = translation.get_language()
Run Code Online (Sandbox Code Playgroud)
Car*_*yer 11
(更新:django-localeurl的LocaleURLMiddleware现在直接支持HTTP Accept-Language作为后备,如果LOCALEURL_USE_ACCEPT_LANGUAGE设置为True.那么OP的所需行为现在可用而无需编写自定义中间件).
同时启用Django的内置LocaleMiddleware和LocaleURLMiddleware是没有意义的.它们旨在作为相互排斥的替代方案,并且在选择语言方面具有不同的逻辑.Locale-url在tin上执行它所说的内容:语言环境由URL组件定义(因此不是由Accept-Language标头定义).Django的LocaleMiddleware将根据会话值或cookie或Accept-Language标头选择语言.启用这两者只意味着最后一个获胜,这就是您看到LocaleURLMiddleware行为的原因.
听起来好像你想要两种混合,其中初始语言(当访问网站的根URL时?)是基于Accept-Language选择的,然后由URL定义?现在还不完全清楚你想要什么样的行为,所以澄清这是第一步.然后,您可能需要编写自己的LocaleMiddleware来实现该行为.您第一次尝试黑客攻击LocaleURLMiddleware总是使用Accept-Language代替URL中定义的内容.相反,您需要在"if not locale:"部分中进一步检查Accept-Language标题,默认为settings.LANGUAGE_CODE.更像这样的东西(未经测试的代码):
def process_request(self, request):
locale, path = self.split_locale_from_request(request)
locale_path = utils.locale_path(path, locale)
if locale_path != request.path_info:
if request.META.get("QUERY_STRING", ""):
locale_path = "%s?%s" % (locale_path, request.META['QUERY_STRING'])
return HttpResponseRedirect(locale_path)
request.path_info = path
if not locale:
if request.META.has_key('HTTP_ACCEPT_LANGUAGE'):
locale = utils.supported_language(request.META['HTTP_ACCEPT_LANGUAGE'].split(',')[0])
else:
locale = settings.LANGUAGE_CODE
translation.activate(locale)
request.LANGUAGE_CODE = translation.get_language()
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13604 次 |
| 最近记录: |