Новости Joomla

0 Пользователей и 1 Гость просматривают эту тему.
  • 25 Ответов
  • 1894 Просмотров
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Проблема с токеном
« : 10.10.2017, 19:04:41 »
Сталкиваюсь с таким впервые, но вообщем отображается форма с токеном:
Код
<?= JHtml::_( 'form.token' )?>
отправляем форму и пустота, а почему пустота? потому что в обработчике:
Код
 if ( !JSession::checkToken() ) exit;
а почему идет выход? правильно потому что токен не совпадает!
Получается что при каждом обращении к странице токен меняется, так же не должно быть!
В чем может быть косяк?
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #1 : 10.10.2017, 21:21:01 »
Бред какой то, сделал вывод просто токена echo JSession::getFormToken() посмотреть как он ведёт себя на странце, и он перестал обновляться при каждой загрузке страницы..
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Проблема с токеном
« Ответ #2 : 10.10.2017, 21:25:44 »
Я сталкивался. Дело в том, что JSession::checkToken() имеет аргумент $method = 'post', а моя форма была без объявления метода, то есть c get.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #3 : 10.10.2017, 21:39:33 »
Я сталкивался. Дело в том, что JSession::checkToken() имеет аргумент $method = 'post', а моя форма была без объявления метода, то есть c get.
нет дело не в том увы, у формы есть method="post" просто при каждом обновлении страницы токен становился другой!
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Re: Проблема с токеном
« Ответ #4 : 10.10.2017, 21:56:14 »
Ну могу  посоветовать разве что лезть в саму функцию и построчно проверять.
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Проблема с токеном
« Ответ #5 : 10.10.2017, 22:01:04 »
cookies включены?
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #6 : 10.10.2017, 22:04:27 »
cookies включены?
конечно

Ну могу  посоветовать разве что лезть в саму функцию и построчно проверять.
Уже не проверить, уже пашет, я выше написал
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Проблема с токеном
« Ответ #7 : 10.10.2017, 22:06:48 »
В чем может быть косяк?
где то есть вызов JSession::getFormToken(true). на форуме видел модуль логина такой когда то.

P.S.
Уже не проверить, уже пашет, я выше написал
т.е. вы просто один раз сделали JSession::getFormToken(), потом убрали, и стало все норм?
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #8 : 10.10.2017, 22:11:30 »
где то есть вызов JSession::getFormToken(true). на форуме видел модуль логина такой когда то.
В сайте нет сторонних компонентов, абсолютно все самописные, и такого вызова точно нет!

P.S.т.е. вы просто один раз сделали JSession::getFormToken(), потом убрали, и стало все норм?
да )
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Проблема с токеном
« Ответ #9 : 10.10.2017, 22:17:44 »
барабашка все таки есть :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Проблема с токеном
« Ответ #10 : 10.10.2017, 22:18:45 »
Весьма любопытно. Какая версия Joomla?
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #11 : 10.10.2017, 22:21:40 »
Весьма любопытно. Какая версия Joomla?
3.7.5, потом обновил до 3.8.1 баг сохранялся )

барабашка все таки есть :)
ага

И я сначала подумал может дело в серваке? но взял и скопировал на опенсервер всё, запустил, баг сохранялся, на обеих платформах с обновлением системы! на локале и на серваке баг пропал после банального echo  JSession::getFormToken();  ;D
*

rkron

  • Захожу иногда
  • 316
  • 7 / 0
Re: Проблема с токеном
« Ответ #12 : 11.10.2017, 04:44:32 »
3.7.5, потом обновил до 3.8.1 баг сохранялся )
ага

И я сначала подумал может дело в серваке? но взял и скопировал на опенсервер всё, запустил, баг сохранялся, на обеих платформах с обновлением системы! на локале и на серваке баг пропал после банального echo  JSession::getFormToken();  ;D

Все правильно. Для каждой сессии свой токен. Обновитесь и баг снова появится. У меня такое было при шифровании пароля. При запуске скрипта каждый раз новый пароль.
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #13 : 11.10.2017, 11:18:24 »
Все правильно. Для каждой сессии свой токен. Обновитесь и баг снова появится. У меня такое было при шифровании пароля. При запуске скрипта каждый раз новый пароль.
Ну да всё правильно для каждой сессии новый токен, но сессия же длится не секунду, то есть при перезагрузке страницы сессия новая!
*

rkron

  • Захожу иногда
  • 316
  • 7 / 0
Re: Проблема с токеном
« Ответ #14 : 11.10.2017, 13:36:09 »
Ну да всё правильно для каждой сессии новый токен, но сессия же длится не секунду, то есть при перезагрузке страницы сессия новая!
Это зависит от формирования токена. При перезагрузке страницы токен формируется заново. Выходом может быть вынос скрипта с токеном и запись в файл или в базу. Затем вытаскивать записанный токен по мере необходимости. Обновление по времени.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Проблема с токеном
« Ответ #15 : 11.10.2017, 13:41:38 »
вы что-то путаете. либо не о том говорите. токен сессии как и говорит @Aleks.Denezh формируется на сессию, а не на 1 страницу. он не должен меняться при просто рефреше страницы, иначе была бы такая проблема у всех с логином и прочим.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

rkron

  • Захожу иногда
  • 316
  • 7 / 0
Re: Проблема с токеном
« Ответ #16 : 11.10.2017, 14:38:26 »
вы что-то путаете. либо не о том говорите. токен сессии как и говорит @Aleks.Denezh формируется на сессию, а не на 1 страницу. он не должен меняться при просто рефреше страницы, иначе была бы такая проблема у всех с логином и прочим.
Да скорее всего говорим про разные вещи.
*

Progreccor

  • Захожу иногда
  • 269
  • 25 / 0
Re: Проблема с токеном
« Ответ #17 : 20.11.2017, 20:27:35 »
может быть кеш?
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #18 : 20.11.2017, 20:52:22 »
может быть кеш?
С сервером какие то проблемы были, после перезагрузки всё исправилось...
*

SeBun

  • BanMaster
  • 4018
  • 259 / 5
  • @SeBun48
Re: Проблема с токеном
« Ответ #19 : 20.11.2017, 21:48:32 »
С сервером какие то проблемы были, после перезагрузки всё исправилось...
С опенсервером тоже проблемы были? Я перезагружал, менял версию пыха, чистил, безрезультатно. При каждой перезагрузке создается новая сессия. Если происходит авторизация, создается сессия админа. А вот токен, помоему, один и тот же в базе, но могу ошибаться, не помню.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #20 : 20.11.2017, 22:07:58 »
С опенсервером тоже проблемы были? Я перезагружал, менял версию пыха, чистил, безрезультатно. При каждой перезагрузке создается новая сессия. Если происходит авторизация, создается сессия админа. А вот токен, помоему, один и тот же в базе, но могу ошибаться, не помню.
Да тоже были, тоже реснул и всё прошло, хотя я ещё до актуальной версии обновил джумлу, а ещё я сделал очистку таблицы с сессиями
*

AlekVolsk

  • Гуру
  • 6915
  • 415 / 4
Re: Проблема с токеном
« Ответ #21 : 20.11.2017, 23:04:29 »
изучаем исходники: JHtml::_( 'form.token' ) - это запрос нового токена для сессии,  JSession::getFormToken() - получение текущего токена
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Проблема с токеном
« Ответ #22 : 20.11.2017, 23:52:31 »
было бы интересно переписать keepalive под jQuery чтобы не подключать оба фреймворка mootools и jquery ради одного keepalive.
keepalive уже давно написан на vanilla js
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
Re: Проблема с токеном
« Ответ #23 : 20.11.2017, 23:59:08 »
изучаем исходники: JHtml::_( 'form.token' ) - это запрос нового токена для сессии,  JSession::getFormToken() - получение текущего токена
Алексей, а ты не заметил какой параметр передаётся в метод getFormToken():

Спойлер
[свернуть]

как думаешь зачем этот параметр $forceNew = false  ::)


я уже создавал такую тему.
Если бы вы внимательно прочитали тему, то заметили бы что токен обновлялся при перезагрузки страницы сразу, то есть нажимаете f5 один токен, через секунду ещё раз f5 токен меняется, ещё через секунду ctrl+f5 снова токен меняется..  при чём тут JHtml::_('behavior.keepalive'); ?


было бы интересно переписать keepalive под jQuery чтобы не подключать оба фреймворка mootools и jquery ради одного keepalive.

3 строчки вам интересно?)
<script>
    jQuery(document).ready(function ($) {
        setInterval(function () {
            $.get('/index.php');
        }, 60000);
    });
</script>
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Проблема с токеном
« Ответ #24 : 21.11.2017, 00:10:44 »
как думаешь зачем этот параметр $forceNew = false  ::)
Даже проще: JHtml::_( 'form.token' ) в конце концов вызывает JHtmlForm::token()
Код
	public static function token()
{
return '<input type="hidden" name="' . JSession::getFormToken(). '" value="1" />';
}
Не будь паразитом, сделай что-нибудь самостоятельно!
*

SeBun

  • BanMaster
  • 4018
  • 259 / 5
  • @SeBun48
Re: Проблема с токеном
« Ответ #25 : 21.11.2017, 01:12:45 »
Да тоже были, тоже реснул и всё прошло, хотя я ещё до актуальной версии обновил джумлу, а ещё я сделал очистку таблицы с сессиями
Мне это не помогло, разные браузеры пробовал, таблицу сессий чистил, перезагружал... Я не хочу кардинально рубить все, мне интересно до проблемы докопаться. Где именно собака зарыта, при каком сочетании обстоятельств такая петрушка вылезает? Код априори рабочий, в этом сомнений нет. Но вот что заставляет его неправильно работать и где ошибка, пока не нашел. Да и не ковырял сильно, если честно... Так что пока с интересом читаю данный топик.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Проблема с полем type=editor внутри type=subform

Автор batiskaf

Ответов: 17
Просмотров: 947
Последний ответ 13.10.2020, 18:17:58
от platonische
Проблема вызова модели компонента из модуля

Автор platonische

Ответов: 1
Просмотров: 574
Последний ответ 24.04.2020, 18:32:32
от platonische
Проблема с классом JFile

Автор dv-cto

Ответов: 2
Просмотров: 750
Последний ответ 24.05.2017, 17:47:42
от dv-cto
[Решено] Проблема с созданием собственного типа поля

Автор batiskaf

Ответов: 2
Просмотров: 869
Последний ответ 22.03.2017, 21:48:31
от batiskaf
Проблема с созданием модуля

Автор stincv

Ответов: 2
Просмотров: 943
Последний ответ 20.01.2015, 09:04:30
от stincv