Django,SESSION_COOKIE_DOMAIN有多个域名

时间:2010-01-22 11:27:12

标签: django django-sessions

在Django中,我将SESSION_COOKIE_DOMAIN设置为我的域名。但我实际上想用两个不同的域名运行同一个站点。

设置SESSION_COOKIE_DOMAIN后,只有指定的域允许用户登录。是否可以允许两个域登录?

5 个答案:

答案 0 :(得分:28)

如果您将会话Cookie域设置为以“。”开头。它将允许您处理通配符子域并跨多个子域共享会话cookie(登录会话)。

In settings.py:
SESSION_COOKIE_DOMAIN=".stackoverflow.com"

以上内容允许在user1.stackoverflow.com和user2.stackoverflow.com之间共享cookie。

如果您确实希望同一网站的网址不同,您是否希望同一用户在一次登录会话中在两个网站之间切换?或者你只是想让两个不同的用户从两个不同的网址(不是子域名)登录到网站?

答案 1 :(得分:5)

标准的SessionMiddleware只支持一个SESSION_COOKIE_DOMAIN,它只适用于一个域及其子域。

以下是基于请求主机动态设置Cookie域的变体。要使用它,只需更新MIDDLEWARE_CLASSES即可使用这一个SessionHostDomainMiddleware,而不是SessionMiddleware。这更好,@ jcdyer和@interstar?

import time

from django.conf import settings
from django.utils.cache import patch_vary_headers
from django.utils.http import cookie_date
from django.contrib.sessions.middleware import SessionMiddleware

class SessionHostDomainMiddleware(SessionMiddleware):
    def process_response(self, request, response):
        """
        If request.session was modified, or if the configuration is to save the
        session every time, save the changes and set a session cookie.
        """
        try:
            accessed = request.session.accessed
            modified = request.session.modified
        except AttributeError:
            pass
        else:
            if accessed:
                patch_vary_headers(response, ('Cookie',))
            if modified or settings.SESSION_SAVE_EVERY_REQUEST:
                if request.session.get_expire_at_browser_close():
                    max_age = None
                    expires = None
                else:
                    max_age = request.session.get_expiry_age()
                    expires_time = time.time() + max_age
                    expires = cookie_date(expires_time)
                # Save the session data and refresh the client cookie.
                # Skip session save for 500 responses, refs #3881.
                if response.status_code != 500:
                    request.session.save()
                    host = request.get_host().split(':')[0]
                    response.set_cookie(settings.SESSION_COOKIE_NAME,
                            request.session.session_key, max_age=max_age,
                            expires=expires, domain=host,
                            path=settings.SESSION_COOKIE_PATH,
                            secure=settings.SESSION_COOKIE_SECURE or None,
                            httponly=settings.SESSION_COOKIE_HTTPONLY or None)
        return response

答案 2 :(得分:4)

我认为这就是你要找的东西,我花了我几个小时才找到它

https://bitbucket.org/uysrc/django-dynamicsites

答案 3 :(得分:0)

您可以将响应Cookie更改为以下内容,而不是使用完整的新SessionMiddleware:

class CrossDomainSessionMiddleware(object):
    def process_response(self, request, response):
        if response.cookies:
            host = request.get_host()
            # check if it's a different domain
            if host not in settings.SESSION_COOKIE_DOMAIN:
                domain = ".{domain}".format(domain=host)
                for cookie in response.cookies:
                    if 'domain' in response.cookies[cookie]:
                        response.cookies[cookie]['domain'] = domain
       return response

(将此中间件置于会话中间件之上)如果您愿意,可以将此限制为特定域。

答案 4 :(得分:0)

我正在使用 django 3.1.4,它对我有用。

像这样创建一个中间件,我在我的应用程序中创建utilities.middleware

class CrossDomainSessionMiddleware:
    def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        response = self.get_response(request)
        if response.cookies:
            host = request.get_host()
            # check if it's a different domain
            if host not in settings.SESSION_COOKIE_DOMAIN:
                domain = ".{domain}".format(domain=host)
                for cookie in response.cookies:
                    if 'domain' in response.cookies[cookie]:
                        response.cookies[cookie]['domain'] = domain
        return response

现在将此中间件放在 settings.py 中的 SessionMiddleware 之上

'utilities.middlware.CrossDomainSessionMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',

确保你的 settings.py 中有这两个变量

SESSION_COOKIE_DOMAIN = '.domain.com'
SESSION_COOKIE_NAME = 'domainsessionid'