PHP利用token防止表单重复提交

本文介绍了一种使用PHP和session来防止表单重复提交的方法。通过生成并验证token确保表单只被处理一次,有效避免了因浏览器刷新等原因导致的数据重复录入问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<?php 
/*  
* PHP简单利用token防止表单重复提交  
*/  
session_start();  
header("Content-Type: text/html;charset=utf-8");  
function set_token() {  
    $_SESSION['token'] = md5(microtime(true));//可以做加密处理  
}  
function valid_token() {  
    $return = $_REQUEST['token'] === $_SESSION['token'] ? true : false;  
    set_token();//重新生成token  
    return $return;  
}  
//如果token为空则生成一个token  
if(!isset($_SESSION['token']) || $_SESSION['token']=='') {  
    set_token();  
}  
if(isset($_POST['web'])){   
    if(!valid_token()){   
        echo "token 验证失败,请不要重复提交!";   
    }else{   
        echo '成功提交表单内容:'.$_POST['web'];   
    }   
}else{  
?>  
    <form method="post" action="">    
    <input type="hidden" name="token" value="<?php echo $_SESSION['token']?>">
    <input type="text" class="input" name="web" value="http://www.youkuaiyun.com">    
    <input type="submit" class="btn" value="提交" />    
    </form>  
<?php      
}  
?> 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值