В моей форме есть скрытое поле:
<input type="hidden" name="auth_token" value="<?php echo $auth_token; ?>">
Это значение также сохраняется в сеансе и переменной:
$_SESSION['auth_token'] = hash('sha256', rand() . time() . $_SERVER['HTTP_USER_AGENT']); # TODO: put this in a function
$auth_token = $_SESSION['auth_token'];
Когда форма отправлена, сравниваются два значения. Это базовый токен формы.
Должно ли это быть преобразовано в две функции или только одну при рефакторинге? set_form_token()
и get_form_token()
, get_form_token () возвращает значение сеанса, затем я могу сравнить его в своем основном коде. Как правильно это сделать?
EDIT:
Учитывая ответы Джоэла Л и Роберта Питта, я сделал следующее:
function set_auth_token()
{
if (!isset($_SESSION['auth_token']))
{
$_SESSION['auth_token'] = hash('sha256', rand() . time() . $_SERVER['HTTP_USER_AGENT']);
}
}
function get_auth_token()
{
if (isset($_SESSION['auth_token']))
{
return $_SESSION['auth_token'];
}
else
{
die('No auth token.');
}
}
function check_auth_token()
{
if (array_key_exists('auth_token', $_SESSION) && array_key_exists('auth_token', $_POST))
{
if ($_SESSION['auth_token'] === $_POST['auth_token'])
{
# what happens if user fills the form in wrong first time(?)
$_SESSION['auth_token'] = hash('sha256', rand() . time() . $_SERVER['HTTP_USER_AGENT']);
}
else
{
return false;
}
}
else
{
return false;
}
}
Затем я могу проверить, возвращает ли check_auth_token значение false или нет, и затем записать его после отправки формы. Это будет приемлемо?