如何在php項(xiàng)目中防止惡意刷新頁(yè)面?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
代碼如下:
<?php
session_start();
$k=$_GET['k'];
$t=$_GET['t'];
$allowTime = 1800;//防刷新時(shí)間
$ip = get_client_ip();
$allowT = md5($ip.$k.$t);
if(!isset($_SESSION[$allowT]))
{
$refresh = true;
$_SESSION[$allowT] = time();
}elseif(time() - $_SESSION[$allowT]>$allowTime){
$refresh = true;
$_SESSION[$allowT] = time();
}else{
$refresh = false;
}
?>
ie6提交兩次我也碰到過(guò),大致是用圖片代替submit時(shí),圖片上有個(gè)submit(),這樣會(huì)提交兩次,如果只是submit鈕我沒(méi)碰到過(guò)提交兩次的情況。
現(xiàn)在整理一下:
方法基本上前面幾位說(shuō)得差不多
接收的頁(yè)即2.php分為兩部分,一部分處理提交過(guò)來(lái)的變量,一部分顯示頁(yè)面
處理變量完畢用header( "location: ".$_SERVER[ 'PHP_SELF '])跳轉(zhuǎn)到自身頁(yè)
本部分要做判斷,如果沒(méi)有post的變量就跳過(guò)。當(dāng)然也可以跳到別的頁(yè)面。
跳到別的頁(yè)面返回時(shí)會(huì)有問(wèn)題,建議做在一個(gè)php文件里。
如果上頁(yè)穿過(guò)來(lái)得變量不符合要求可以強(qiáng)制返回
復(fù)制代碼 代碼如下:
<script>
history.go(-1);
</script>
只說(shuō)了一下大體思路,也許高手們不會(huì)遇到此類(lèi)問(wèn)題,可是并不是每個(gè)人都是高手。
2.php的流程
復(fù)制代碼 代碼如下:
if(isset($_POST))
{ 接收變量
if(變量不符合要求)
<script> history.go(-1); </script>
else
操作數(shù)據(jù)
...
if(操作完成)
header( "location: ".$_SERVER[ 'PHP_SELF ']);
}
<script language= "JavaScript ">
<!--
javascript:window.history.forward(1);
//-->
</script>
關(guān)于如何在php項(xiàng)目中防止惡意刷新頁(yè)面問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
分享文章:如何在php項(xiàng)目中防止惡意刷新頁(yè)面-創(chuàng)新互聯(lián)
標(biāo)題鏈接:http://chinadenli.net/article8/dihsop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、企業(yè)建站、定制開(kāi)發(fā)、網(wǎng)站設(shè)計(jì)公司、面包屑導(dǎo)航、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容