Я скопировал существующий и успешно запущенный сайт на новый сервер разработки.Невозможно изменить имя файла cookie php
Войти на новом сервере теперь сломана, и я отслеживали его сводится к тому, что, хотя куки сессии переименовывается ...
ini_set('session.name', 'DOMAIN1');
... браузер продолжает хранить sesssion печенье как PHPSESSID.
Когда я удаляю указанную выше строку из приложения на новом сервере, вход снова работает. Но это нехорошее решение, потому что другое приложение также использует PHPSESSID под этим именем.
И я предпочел бы найти причину странного поведения вместо использования обходного пути. Если я не исправлю это, это может укусить меня в другом месте.
Возможно, это уже достаточно информации для кого-то, чтобы дать мне подсказку. Если нет, какая информация будет полезна?
Эта машина была очень голым и базовым сервером ubuntu 8.04, и я установил apache2, mysql и php5 с aptitude. Я также обновил lokales и часовой пояс.
Решение:
Я заменил строку выше с этим кодом из из принятого ответа ...
if(ini_set('session.name', 'DOMAIN1') === false || !session_name('DOMAIN1'))
{
die('Unable to set sesssion scope');
}
... и Войти теперь работает на новом сервере.
Нет, ini_set() не должен изменять файл INI: см. Http://php.net/ini_set. В противном случае это было бы большим потенциальным нарушением безопасности. – mojuba
Да, извините, только время выполнения :) – RobertPitt
Спасибо, после долгих поисков он наконец работает. Я заменил старый код 4 строками из вашего примера и исправил его! – mit