Можно ли использовать один и тот же сеанс для нескольких доменных имен в Django?

У меня есть приложение Django (доменное имя: app.com), которое позволяет пользователям создавать шаблон и размещать его на поддомене (example.app.com), используя фреймворк Django sites.

Использование этой опции:

SESSION_COOKIE_DOMAIN=".app.com"

Сайты под этим доменом используют одну и ту же сессию, но когда пользователь размещает шаблон на своем доменном имени (custom.com), каждый сайт имеет свою собственную сессию.

Можно ли сделать так, чтобы все сайты этого приложения Django использовали одну и ту же сессию?

Почему?

Так что мне не придется снова входить в систему каждый раз, когда я посещаю один из этих сайтов.

Я пробовал это промежуточное ПО, но оно все еще не работает.

import time

from django.conf import settings
from django.utils.cache import patch_vary_headers
from django.utils.http import http_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 = http_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

Я ценю вашу помощь.

Вернуться на верх