表单令牌
在生成表单的时候,为防止表单重复提交。在form表单中添加一个隐藏的input标签来存放令牌,等到提交的时候,和表单一起提交。提交以后和生成的session值作比较,通过这种方式来达到防止重复提交的目的。简要代码如下,
判断我们生成的代码存储在session中的和post 过来的隐藏域的是否一致 相同则重复提交
例子,session方法
[html] view plain copy
1. <?php
2. if($_POST){
3. if($_SESSION["token"]!=$_POST["token"]){
4. die("非法提交!");
5. }else{
6. echo "安全提交!";
7. }
8. }
9. $_SESSION["token"]=md5(rand(1,999));//没生成一次表单,修改一次值,不要在post处理前修改它,不然无法比对
10. ?>
11. <form action="1.php" method="post">
12. <input type="hidden" value="<?php echo $_SESSION["token"]?>" name="token">
13. <input type="submit" value="提交" />
14. </form>from:http://www.111cn.net/phper/phpanqn/58764.htm ;
例子,cookie+md5方法
[php] view plain copy
1. <?php
2.
3. $value = $_COOKIE[“value”]; //读取上一次设置的Cookie值
4.
5. if(count($_POST)) {
6.
7. $long = “”;
8.
9. while(list($key,$value)=each($_POST))$long.=$value;
10.
11. $hash = md5($long);
12.
13.
14. setcookie(“value”,$hash,time()+60*60); //重新设置cookie
15.
16. }
17.
18. if($value!=$hash) {
19.
20. // 如果两次的MD5值不一样就对数据进行进一步操作
21.
22. } else {
23.
24. //如果两次MD5的值相同,告知用户提交失败 ,为重复提交表单
25.
26. }
27.
28. ?>
防止表单重复提交
原创
©著作权归作者所有:来自51CTO博客作者壹小小俊的原创作品,请联系作者获取转载授权,否则将追究法律责任
上一篇:Docker 删除镜像
下一篇:第五课--文本格式
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
redis防止重复提交
redis缓存 setIfAbsent防止重复提交
redis 缓存 重复提交 setIfAbsent -
Vue防止表单重复提交
在提交表单时按钮点击一次后,为防止重复表达提交,需要将提交按钮置灰。这
Vue html 重复提交 -
token防止表单重复提交
出现表单重复提交的三种情况: 一、服务器响应缓慢,用户多次点击提交按钮。 二、提交成功后刷新页面。 三、提交成功后返回表单页面再次点击提交。
java xml html 表单 重复提交