程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php防止站外遠程提交表單的方法,php提交表單

php防止站外遠程提交表單的方法,php提交表單

編輯:關於PHP編程

php防止站外遠程提交表單的方法,php提交表單


這篇文章主要介紹了php防止站外遠程提交表單的方法,實例演示了通過session與驗證碼進行提交過濾的方法,非常實用,需要的碼農可以參考下

本文實例講述了php防止站外遠程提交表單的方法,分享給大家供大家參考。具體實現方法如下:

一般來說防止站長提交表單無非就是對每一次打開表單或提交數據都會需要加一個token來進行驗證了,這個其實與驗證碼做法沒什麼兩樣了,下面來看幾個防止站外遠程提交表單的例子。

例子一:我們每一次打開提交頁面生成一個token然後保存在session中,當表單提交時我們來判斷當前的token值與session是否一致,如果是的就是正常提交否則就是無效提交了。

具體代碼如下:

<?php     
session_start();     
     
if ($_POST['submit'] == "go"){     
    //check token     
    if ($_POST['token'] == $_SESSION['token']){     
        //strip_tags     
        $name = strip_tags($_POST['name']);     
        $name = substr($name,0,40);     
        //clean out any potential hexadecimal characters     
        $name = cleanHex($name);     
        //continue processing....     
    }else{     
        //stop all processing! remote form posting attempt!     
    }     
}     
     
$token = md5(uniqid(rand(), true));     
$_SESSION['token']= $token;     
     
 function cleanHex($input){     
    $clean = preg_replace("![\][xX]([A-Fa-f0-9]{1,3})!", "",$input);     
    return $clean;     
}     
?>     
<form action="<?php echo $_SERVER['PHP_SELF'];?>" method="post">     
<p><label for="name">Name</label>     
<input type="text" name="name" id="name" size="20" maxlength="40"/></p>     
<input type="hidden" name="token" value="<?php echo $token;?>"/>     
<p><input type="submit" name="submit" value="go"/></p>     
</form>

還有一種比較明顯的做法就是利用驗證碼了,這種驗證碼的方式與其它的方式是一樣的哦,下面看個簡單的例子

 

例子二:增加驗證碼

表單提交時候增加驗證碼,可以有效防止灌水機提交數據。但是隨著圖形圖像識別程序變的更加強大,驗證碼識別也不斷的在提高他的難度,有些驗證碼甚至加入了聲音的識別,一些小站點可以采用這樣的方式。

if($_POST['vcode'] != get_vcode())
{
    exit('驗證碼校驗失敗,無法入庫');
}

具體的例子感興趣的讀者可以在網上到很多驗證的相關例子。

原文地址:http://www.manongjc.com/article/678.html

相關閱讀:

php防止跨域提交表單

js jsonp方式解決跨域請求

php提交表單時判斷 if($_POST[submit])與 if(isset($_POST[sub

php 多個submit提交表單處理方法

php ajax無刷新提交表單

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved