php token函数,php - 设置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()返回会话值,然后可以在主代码中进行比较。 正确的做法是什么?

编辑:

考虑到Joel L和RobertPitt的回答,我做出了这些:

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,然后在提交表单后记录下来。 这可以接受吗?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值