确保您的表单是从您的页面提交的!也可以通过向查询字符串添加 &token 并使用 $_GET 对其与会话数据(或您喜欢的任何数组)进行检查来将其应用于 URL,这并不是说此字符串是随机生成的并存储的。如果您不想使用 $_SESSION,您可以构建自己的数组来存储生成的字符串,例如,您可以将其设为 $tokens = array(),并在您的 easysecure 类中将所有内容存储在该数组中!
<?php
class easysecure {
var $curr_user;
var $curr_permission;
var $curr_task;
var $validpermission;
var $error;
function &setVar( $name, $value=null ) {
if (!is_null( $value )) {
$this->$name = $value;
}
return $this->$name;
}
function maketoken($formname, $id){
$token = md5(uniqid(rand(), true));
$_SESSION[$formname.$id] = $token;
return $token;
}
function checktoken($token, $formname, $id){
if(!$token){
$this->setVar('validpermission', 0);
$this->setVar('error', '未找到令牌,检测到安全桥');
return false;
}
$key = $_SESSION[$formname.$id];
if($key !== $token ){
$this->setVar('validpermission', 0);
$this->setVar('error', '无效令牌');
return false;
}
if($this->validpermission !==1){
echo '运行此脚本的权限无效';
return false;
}else{
return true;
}
}
}
?>
<?php $userid = *** ?>
<form name="newform" action="index.php" method="post">
<input type="text" name="potentialeveilfield" value="" size 30 />
<input type="hidden" name="token" value="<?php echo maketoken(newform, $userid); ?>" />
<input type="submit" />
</form>
现在,在处理表单时... 检查令牌的值
<?php
if(!checktoken($_POST['token'], 'newform', $userid))
{ exit(); }
?>