本节内容:
php防止页面重复提交
说是php中防止页面的重复提交,其实还说到了js代码防止重复提交的方法。
1、提交按钮置disabled
当用户提交后,立即把按钮置为不可用状态。这种用js来实现。
提交前:
$("#submit").val("正在提交,请稍等");
执行后,把按钮置为原来状态:
$("#submit ").val("确定提交");
2、过期时间法
思路:
当用户提交按钮后生成一个token(每次业务提交token 为唯一值)存入session,并设置过期时间。
当用户再此提交时,检测token是否一致且是否过期,若一致且没有过期,则认为提交了二次。
当程序执行出错时,则需要清除存入session的值。
例子:
//防止页面重复提交
function checkRepeatSubmit($uniqueid = '', $expire = 30) {
$uniqueid = empty($uniqueid) ? Yii::app()->user->id . Yii::app()->user->name . Yii::app()->user->mihome : $uniqueid;
$token = md5("wms_check_repeat" . $uniqueid);
$time = time();
if (isset()($_SESSION['token']) && !empty($_SESSION['token']) && $_SESSION['token'] == $token && ($time - $_SESSION['expire_time'] < $expire)) {
return false;
} else { // www.
$_SESSION['token'] = $token;
$_SESSION['expire_time'] = $time;
//session写入的时候会等待整个页面加载完成,用此函数可以立即写入
session_write_close();
return true;
}
}
//删除存入的值
function cancelRepeatSubmit() {
unset($_SESSION['token']);
unset($_SESSION['expire_time']);
}
3、token销毁法
思路:
当页面进行加装的时候生成token,存在session中,并写在表单里。
表单提交时,随表单提交给服务端,服务端通过session存入的token与token进行比较,若相等,则销毁seesion中存入的token,当页面遭到二次提交的时候,由于存入session中的token不存在而报错。
相关阅读:
php token防止表单重复提交的实例代码
例子:
<?php
/**
* 第二种方案
* 1、产生token,并存在session中
* 2、随页面生成
* 3、提交页面与session进行比对,成功后对session进行销毁
* 4、第二次提交则不存在这个值而报错
* @param type $uniqueid
* @return type
*/
function createToken($uniqueid) {
$uniqueid = empty($uniqueid) ? Yii::app()->user->id . Yii::app()->user->name . Yii::app()->user->mihome : $uniqueid;
$token = md5("wms_check2_repeat" . $uniqueid);
$_SESSION['form_token'] = $token;
?session_write_close();
return $token;
}
function checkToken($token) {
if (!isset($_SESSION['form_token']) || empty($_SESSION['form_token']) || $_SESSION['form_token'] != $token) {
return false;
} else {
unset($_SESSION['form_token']);
return true;
}
}
小结:
个人感觉,第一种跟第二种方法配合着用会达到更好的效果。
第二种方法与第三种方法个人感觉第三种要有优势点。
第二种与第三种方法都是把token写在session中,这种方法好处是节省存储空间,但坏处是由于session是需要整个页面加载完毕才能写入,故当整个页面加载比较慢,且用户点击多次提交,可能由于session还没写入导致系统还认为是第一次输入。
导致验证不起作用。
不过,php函数提供了一个牛逼的函数:session_write_close(),可以立即把session写入,不用等待页面加载完成。
同时,对于session的存入也有很多种方法可以选择,可以存在redis,memcache或者数据库都可以的。
您可能感兴趣的文章:
php防止表单重复提交的小例子
php防止刷新页面重复提交的代码一例
php防止用户刷新 重复提交的方法
本节内容:
php中的三个数组操作函数array_map,array_filter,array_walk的用法与区别。
1,array_walk函数:
array_walk()返回布尔值,如果回调函数需要直接作用于数组中的值,则给回调函数的第一个参数指定为引用。这样任何对这些单元的改变也将会改变原始数组本身。此函数可以同时获取到数组的key和value。
2,array_map函数:
array_map() 返回一个数组,该数组包含了 arr1 中的所有单元经过 callback 作用过之后的单元。callback 接受的参数数目应该和传递给 array_map() 函数的数组数目一致。
回调函数对数组中每个值都会产生最终影响,并在调用array_map的返回值中体现。
此函数可以同时对多个数组进行操作。并最终合并为一个数组(每个数组根据下标平行对其到同一个二维数组中)。
3,array_filter函数:
此函数是专门用于过去数组中的元素,简单说就是对数组中的经过回调函数判断的value进行过滤,并通过array_filter()函数返回处理后的数组。
其中,array_walk和array_map来做数组的预处理,最常见的是对每个数组值的trim操作。
分享一个例子,来体会下array_map,array_filter,array_walk的区别:
$tmp = array(' AAAA BBBB CCCC ', 'aaaa bbbb c ', ' dddddd eeeeee');
function array_walk_func(&$v, $k) {
$v = trim($v);
}
array_walk($tmp, 'array_walk_func');
var_dump($tmp);
function array_map_func($v) { //www.
return trim($v);
}
$ret = array_map('array_map_func', $tmp);
var_dump($ret);
输出结果:
[0] =>
string(14) "AAAA BBBB CCCC"
[1] =>
string(11) "aaaa bbbb c"
[2] =>
string(13) "dddddd eeeeee"
}
array(3) {
[0] =>
string(14) "AAAA BBBB CCCC"
[1] =>
string(11) "aaaa bbbb c"
[2] =>
string(13) "dddddd eeeeee"
}
本节内容:
微博 短链接
实现思路:
1)、将长网址md5生成32位签名串,分为4段, 每段8个字节;
2)、对这四段循环处理, 取8个字节, 将他看成16进制串与0x3fffffff(30位1)与操作, 即超过30位的忽略处理;
3)、这30位分成6段, 每5位的数字作为字母表的索引取得特定字符, 依次进行获得6位字符串;
4)、总的md5串可以获得4个6位串; 取里面的任意一个就可作为这个长url的短url地址;
PHP代码示例:
/**
* 微博 短链接
* by www.
*/
function shorturl($url='', $prefix='', $suffix='‘) {
$base32 = array (
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
'q', 'r', 's', 't', 'u', 'v', 'w', 'x',
'y', 'z', '0', '1', '2', '3', '4', '5’);
$hex = md5($prefix.$url.$suffix);
$hexLen = strlen($hex);
$subHexLen = $hexLen / 8;
$output = array();
for ($i = 0; $i < $subHexLen; $i++) {
$subHex = substr ($hex, $i * 8, 8);
$int = 0x3FFFFFFF & (1 * (‘0x'.$subHex));
$out = '';
for ($j = 0; $j < 6; $j++) {
$val = 0x0000001F & $int;
$out .= $base32[$val];
$int = $int > 5;
}
$output[] = $out;
}
return $output;
}
$urls = shorturl('http://www.);
var_dump($urls);