【问题标题】:Django, SESSION_COOKIE_DOMAIN with multiple domainsDjango,具有多个域的 SESSION_COOKIE_DOMAIN
【发布时间】:2011-01-08 04:19:54
【问题描述】:

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

设置 SESSION_COOKIE_DOMAIN 后,只有命名域允许用户登录。是否可以允许两个域都登录?

【问题讨论】:

    标签: django django-sessions


    【解决方案1】:

    我使用的是 django 3.1.4,它对我有用。

    创建一个像这样的中间件,我在我的应用程序实用程序中创建。中间件

    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'
    

    【讨论】:

    • 但是当试图删除cookie时,那些你更改域的cookie,我试过了,无法删除。您有删除它们的解决方案吗?谢谢。
    【解决方案2】:

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

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

    【讨论】:

    【解决方案3】:

    标准的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
    

    【讨论】:

    • 他所要求的正是站点框架旨在适应的用例。建议“不要那样做”是没有帮助的。
    • 实际上没有@jcdyer,设置了SESSION_COOKIE_DOMAIN,他将无法使用普通的SessionMiddleware和站点框架。
    • 十年后,我认为这不再有效。我们有这种设置和 django 3.2 错误说你不能在没有SessionMiddleware 的情况下使用管理员所以它没有检测到子类。
    【解决方案4】:

    如果您将会话 cookie 域设置为以“.”开头字符它将让您处理通配符子域并在多个子域之间共享会话 cookie(登录会话)。

    在 settings.py 中: SESSION_COOKIE_DOMAIN=".stackoverflow.com"

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

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

    【讨论】:

    • 我想要第二个。不是子域。基本上我有一个客户有一个非常长的域名thatno-onewantstotype.net 和 quickname.net 并且该站点需要同时为两者工作。
    • 如何添加从longname.netshortname.net 的重定向,以便所有用户只使用shortname.net
    • 也可以在example.comwww.example.com 之间工作。
    猜你喜欢
    • 2010-11-25
    • 2013-11-25
    • 1970-01-01
    • 2011-03-06
    • 2013-07-21
    • 1970-01-01
    • 1970-01-01
    • 2013-03-15
    • 2012-12-25
    相关资源
    最近更新 更多