当前位置:首页 » 编程语言 » php重复提交

php重复提交

发布时间: 2022-06-12 21:14:46

‘壹’ php通过记录IP来防止表单重复提交方法分析

本文实例分析了php通过记录IP来防止表单重复提交方法。分享给大家供大家参考。具体分析如下:
这个原理比较的简单就是用户第一次提交时我们记录提交用户的IP地址,这样如果用户在固定时间内再次提交表单就会提示重复提交了,这种做法通常用于在顶一下,支持一下这种应用中了,在防止数据重复提交是一个非常不好的选择.
例子,代码如下:
复制代码
代码如下:<?php
session_start();
if(empty($_SESSION['ip']))//第一次写入操作,判断是否记录了IP地址,以此知道是否要写入数据库
{
$_SESSION['ip']=$_SERVER['REMOTE_ADDR'];//第一次写入,为后面刷新或后退的判断做个铺垫
mysql_query("INSERT
INTO
admin(id,
name,
age)
VALUES(123,
'姚明',
25)");//写入数据库操作
}
else//已经有第一次写入后的操作,也就不再写入数据库
{
echo
'请不要重复提交表单或刷新页面';//写一些已经写入的提示或其它东西
}
?>
还有办法就是:
1:在页面生成随机码,也就是每次提交随机码都不一样,在提交的时候验证随机码!
2:在提交的时候,验证如果数据存在,就不提交了.
如果你想防止重复提交入库IP不是最好的办法,我们可以在数据库中查询是不是有相同记录并且IP是不是想同再进行处理.
例子,代码如下:
复制代码
代码如下:$sql
="select
*
from
表名
where
buy_tel='电话'
and
IP='$ip'
";//
and
$time-buy_date<60
$query
=
$db->query(
$sql
);
if(
$db->rows(
$query
)
)
{
echo('<script>alert("您己提交过了,请勿重复提交!");</script>');
}
else
{
//进行入库操作
}
希望本文所述对大家的PHP程序设计有所帮助。

‘贰’ PHP如何防止form重复提交

1. 使用JS让按钮在点击一次后禁用(disable)。采用这种方法可以防止多次点击的发生,实现方式较简单。

缺点是若客户端禁止JavaScript脚本,则失效。

2. 在提交成功后执行页面重定向(redirect)。转到提交成功信息页面。

特点:避免F5重复提交,消除浏览器前进和后退按钮可导致的同样问题。

3. 表单隐藏域中存放session(表单被请求时生成的标记)。采用此方法在接收表单数据后,检查此标志值是否存在,先进行删除,然后处理数据; 若不存在,说明已提交过,忽略本次提交。

//服务端生成随机数存入session,分配至表单页
$data['sess_id']=$_SESSION['sid']=mt_rand(1000,9999);
$this->load->view('form',$data);

//表单页隐藏域存放此session值
<inputtype="hidden"name="sid"value="<?=$sess_id;?>">

//处理
if($_POST['sid']!=''&&$_POST['sid']==$_SESSION['sid'])
{
unset($_SESSION['sid']);

echo'处理数据';
}
else
{
echo'已提交过表单';
}

4. 数据库唯一索引约束(最有效的防止重复数据的方法)。

5. 使用验证码

‘叁’ 如何真正解决表单重复提交问题php代码

在表单中添加一个隐藏域token,就是个随机数,由php生成,同时保存在session中;当表单提交时,比对token和session中存储的值是否一样,如果一致则通过,清除session中的保存的token;不一致则不通过

‘肆’ php如何防止重复提交

您可以加上表单令牌,或者使用随机数的方式来阻止

‘伍’ PHP 怎么防止GET方式提交重复数据

PHP 防止表单重复提交,使用令牌来做验证,即可解决。示例如下:

index.php:

<?php
header("Content-type:text/html;charset=utf-8");
//开启session
session_start();

//如果令牌为空,则生成一个令牌
if(!isset($_SESSION['token'])||$_SESSION['token']==""){
//给当前表单生成一个令牌
$_SESSION['token']=md5(microtime(true));
}
?>
<formmethod="get"action="deal.php">
名称:<inputtype="text"name="names"><br/>
描述:<inputtype="text"name="desc"><br/>
<inputtype="text"name="token"value="<?=$_SESSION['token']?>">
<inputtype="submit"value="提交">
</form>

deal.php:

<?php
header("Content-type:text/html;charset=utf-8");
//开启session
session_start();
//验证令牌
if($_REQUEST['token']===$_SESSION['token']){
//表单已经提交,重新生成令牌
$_SESSION['token']=md5(microtime(true));
echo"表单提交成功:<br/>";
print_r($_REQUEST);
}else{
echo"重复提交";
}
?>
热点内容
微信什么资料都没怎么找回密码 发布:2024-05-19 05:35:34 浏览:906
填志愿密码是什么 发布:2024-05-19 05:30:23 浏览:317
城堡争霸自动掠夺脚本 发布:2024-05-19 05:22:06 浏览:203
asp编程工具 发布:2024-05-19 05:20:36 浏览:142
insertpython 发布:2024-05-19 05:12:26 浏览:243
androidant编译 发布:2024-05-19 05:04:11 浏览:987
按键脚本优化 发布:2024-05-19 04:59:57 浏览:751
怎么下载压缩包 发布:2024-05-19 04:47:47 浏览:9
二嫂水仙ftp 发布:2024-05-19 04:47:42 浏览:160
云隙服务器下载 发布:2024-05-19 04:33:22 浏览:315