php防止跨站表单,防止form表单重复提交和防跨站请求攻击

本文介绍了如何使用PHP的随机函数生成一个随机码并存入session,以此来防止表单的重复提交和非法请求。在表单页面生成随机码,并在提交时与session中的值进行对比。如果匹配则通过,否则提示重复提交或非法请求。此外,还提供了一个简单的解决方案,即提交成功后利用JS进行页面跳转,避免刷新导致的重复提交。
摘要由CSDN通过智能技术生成

利用php随机函数生成一个随机码,然后写入到session,在form表单中放置这个随机码,提交的时候进行并对,如果两个值不一致,就是重复提交或非法请求了,当页面刷新后又生成一个新的随机码,再比对。

//表单页面

session_start();

$s_code = md5(mt_rand(0,10000000));

$_SESSION['s_code']=$s_code;

?>

//表单处理页面

$c_code = $_POST['code'];

if($c_code == $_SESSION['s_code']){

//通过

}else{

exit('重复提交或非法请求!');

}

?>

◆另外一个简单粗暴的方法:echo "";

当提交成功后,加上js跳转,再刷新页面就不会重复提交了。当浏览器再返回上一页的时候会提示文档已过期,也不会重复提交数据。window.location.href='index.php';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值