首页 > 编程技术 > php

php利用cookie防止重复提交解决办法

发布时间:2016-11-25 17:31

本文章介绍了关于如何利用cookie来防止用户重复提交相同的数据的解决办法,

原理是
如果数据通过了上边的两次验证,说明数据是合法有效的数据。这时候我们把提交的数据串接为一个字符串,并用MD5加密后得到一个MD5的值,接着我们把这个值通过Cookie放进客户端,当用户下一次提交表单的时候我们就重新操作这一步,并且读出Cookie中的MD5值,进行比较,如果相同就可断定用户提交两次提交的表单是相同的,否则替换这个Cookie!

 

 代码如下 复制代码
<?php
//……
$lasthash = $HTTP_COOKIE_VARS["lasthash"]; //读取上一次设置的Cookie值
 
if(count($HTTP_POST_VARS)) {
    $long = "";
    while(list($key,$value)=each($HTTP_POST_VARS))$long.=$value;
    $hash = md5($long);
    setcookie("lasthash",$hash,time()+60*60*24*30); //重新设置cookie
}
 
if($lasthash!=$hash) {
    // 如果两次的MD5值不一样就对数据进行进一步操作
}
else {
    //如果两次MD5的值相同,告知用户提交失败
}
//……
?>
本文章分享一款只要三行就能取得你指定城市天气信息的php+google api实现代码,有需要的朋友可以参考一下。
 代码如下 复制代码

<?
$xml = simplexml_load_file('http://www.google.com/ig/api?weather=长沙');
$information = $xml->xpath("/xml_api_reply/weather/current_conditions/condition");
echo $information[0]->attributes();

?>

php删除目录及文件的文件原是就是先检查此目录下是否有文件,如果有,是文件夹的话就再调用此函数删除,如果是文件就直接调用 unlink 删除,最后删除此目录。

行删除文件夹的操作时,必须首先确保您有这个权限!

 代码如下 复制代码

<?php
// 说明: 删除非空目录的解决方案

function removeDir($dirName)
{
    if(! is_dir($dirName))
    {
        return false;
    }
    $handle = @opendir($dirName);
    while(($file = @readdir($handle)) !== false)
    {
        if($file != '.' && $file != '..')
        {
            $dir = $dirName . '/' . $file;
            is_dir($dir) ? removeDir($dir) : @unlink($dir);
        }
    }
    closedir($handle);
 
    return rmdir($dirName) ;
}
?>

本文章介绍一篇较实用的文章关于php做站内搜索并高亮显示关键字,这个很多朋友直接利用preg_replace来操作,这是正确的哦,不过我觉得用str_replace更快一些哦。至于原因自己查查这两个函数的区别吧。

如何使用php做站内搜索并高亮显示关键字?

 代码如下 复制代码

<?php

       require_once 'sqlTools.class.php';//封装类,可执行dql、dml语句

       $info=$_POST['info'];

       $sql="select name,password,email from user_500 where name like '%$info%' or password like '%$info%' or email like '%$info%'";

       $sqlTools=new  SqlTools();

       $res=$sqlTools->execute_dql($sql);

       while ($row=mysql_fetch_assoc($res)){

              $row['name']=preg_replace("/($info)/i","<b style="color:red">\1</b>",$row['name']);

              $row['password']=preg_replace("/($info)/i","<b style="color:red">\1</b>",$row['password']);

              $row['email']=preg_replace("/($info)/i","<b style="color:red">\1</b>",$row['email']);

              echo $row['name']."-->".$row['password']."-->".$row['email']."<br>";

       }   

?>

思路分析:

将sql语句中包含的%$info%交给DBMS执行的时候,他会查找字段中含有变量$info的值的信息,

%$info--->查找以$info的值结束的信息

$info%--->查找以$info的值开头的信息

 

通过正则函数preg_replace()将搜索到的关键字高亮显示,比如,

 

$row['name']=preg_replace("/($info)/i","<b style="color:red">\1</b>",$row['name']);

的意思是:通过POST方接收到的值$info替换为加上样式(红色加粗)的结果,并将结果重新赋给$row[‘name’]

如果要搜索多个关键字的话,可以对接收到值$info进行分割,比如$info_more=explode(" ",$info);//这种方式能对以空格隔开的关键字进行分割,再对分割后的结果挨个进行查询,同样,可以使用正则表达式函数进行替换工作,以高亮显示关键字

 代码如下 复制代码

sqlTools.class.php的源代码:

<?php

       class SqlTools{

              private $host="localhost";

              private $dbname="test";

              private $dbuser="root";

              private $dbpwd="";

              private $conn;

              public function __construct(){

                     $this->conn=mysql_connect($this->host,$this->dbuser,$this->dbpwd);

                     if(!$this->conn){

                            die("连接数据库失败".mysql_error());

                     }

                     mysql_select_db($this->dbname,$this->conn) or die("找不到该数据库".mysql_error());

                     mysql_query("set names utf8");

              }

              public function execute_dml($sql){

                     $bool=mysql_query($sql);

                     if ($bool){

                            if ($bool>0) {

                                   return 1;

                            }else{

                                   return 2;

                            }

                     }else {

                            return 0;

                     }

              }

              public function execute_dql($sql){

                     $res=mysql_query($sql);

                     return $res;

              }

              public function close_conn(){

                     mysql_close($this->conn);

              }

       }

?>

本文章主要是介绍了在php中操作json格式数据转换程序,我们利用了json_decode()和json_encode()这两个函数来进行操作方便很多,有需要学习的朋友可以参考一下本实例。

第一步我们利用json_encode()函数把数据转换成json数据

 代码如下 复制代码
<?php
//php中用数组表示JSON格式数据
$arr = array(
'firstname' => iconv('gb2312', 'utf-8', '非诚'),
'lastname' => iconv('gb2312', 'utf-8', '勿扰'),
'contact' => array(
'email' =>'fcwr@111cn.net',
'website' =>'http://www.111cn.net',
)
);
//将数组编码成JSON数据格式
$json_string = json_encode($arr);
//JSON格式数据可直接输出
echo $json_string;
?>

此转换函数只支持utf-8格式的如果中间有中文可以利用iconv或者mb转为UTF-8再进行json_encode,这样就不会有任何问题。

第二步,对数据进行解析我们也用一个php json处理函数json_decode()了,代码如下

 代码如下 复制代码
<?php
//php中用数组表示JSON格式数据
$arr = array(
'firstname' => iconv('gb2312', 'utf-8', '非诚'),
'lastname' => iconv('gb2312', 'utf-8', '勿扰'),
'contact' => array(
'email' =>'fcwr@111cn.net',
'website' =>'http://www.111cn.net',
)
);
//将数组编码成JSON数据格式
$json_string = json_encode($arr);
//将JSON格式数据进行解码,解码后不是JSON数据格式,不可用echo直接输出
$obj = json_decode($json_string);
//强制转化为数组格式
$arr = (array) $obj;
//按数组方式调用里面的数据
echo iconv('utf-8','gb2312',$arr['firstname']);
echo '</br>';
//输出数组结构
print_r($arr);
?>

好了实例就讲到了这里了关于
json_decode()参考 http://www.111cn.net/phper/18/32827.htm
json_encode()参考 http://www.111cn.net/phper/18/32827.htm

标签:[!--infotagslink--]

您可能感兴趣的文章: