Сеансы Laravel не сохраняются с несколькими доменами

Я использую промежуточное программное обеспечение, выбирая контент в зависимости от домена, но только в одном из них сохраняются сеансы. Идея не в том, чтобы разделить сеансы между ними. Каждый домен должен иметь свои сеансы.

Примером проблемы является то, что токены CSRF обновляются при каждой перезагрузке.

Я пытался установить конфигурации для каждого домена (имя файла cookie, путь, домен) и пробовал файлы cookie, файлы и базу данных. Ничего из этого не сработало.

Часть промежуточного кода:

config([
    'session.domain' => $domain,
    'session.cookie' => $slugDomain . '_session',
    'session.path' => '/' . $slugDomain
]);
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
80
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Есть несколько способов сделать это, здесь я делюсь одним вариантом: Вы можете передать идентификатор в URL-адресе домена 1, а затем сохранить этот идентификатор в файле cookie домена 2:

Вы можете создать файл cookie для определенного сеанса:

Route::get('setcookie', function(){
  Session::setId($_GET['id']);
  Session::start();
  return 'Cookie created';
});`

Тогда вы сможете получить своего пользователя с помощью $user = Auth::User;

Вот как я нашел решение в моем случае.

Другим решением является установка домена в app/config/session.php следующим образом:

'domain' => '.domain.com'

источник

Это решение предназначено для общего сеанса между доменами и субдоменами. В моем случае я хочу использовать отдельные сеансы для каждого домена.

Gabriel Jacinto 28.05.2019 16:37
Ответ принят как подходящий

Я нашел проблему. Случается, что промежуточное ПО модифицировало URI, но с двумя полосами в конце URI. Контроллеры выполнялись нормально, но из-за двойных полос в конце сеансов URI не сохранялись.

Новый код:

//...
    $newReq = $request->duplicate();
    $newPath = '/store' . (substr($request->path(), 0, 1) === '/' ? '' : '/') . $request->path();
    $newReq->server->set('REQUEST_URI', $newPath);

    return $next($newReq);

$newPath раньше было

$newPath = '/store/' . $request->path();

Другие вопросы по теме