這次給大家帶來PHP+Session防止表單重複提交步驟詳解,PHP+Session防止表單重複提交的注意事項有哪些,下面就是實戰案例,一起來看一下。
index.php
當前表單頁面is_submit設為0
SESSION_START(); $_SESSION['is_submit'] = 0;<form id="reg" action="post.php" method="post"> <p>使用者名稱:<input type="text" class="input" name="username" id="user"></p> <p>密 碼:<input type="password" class="input" name="password" id="pass"></p> <p>E-mail:<input type="text" class="input" name="email" id="email"></p> <p><input type="submit" name="submit" class="btn" value="提交註冊"/></p> </form>
post.php
若是提交表單了,設當前'is_submit為1,若是重新整理post.php,那麼將執行else代碼
SESSION_START(); if (isset($_POST['submit'])) { if ($_SESSION['is_submit'] == '0') { $_SESSION['is_submit'] = '1'; echo "代碼塊,要做的事,代碼...<a onclick='history.go(-1);' href='javascript:void(0)'>返回</a>"; } else { echo "請不用重複提交<a href='index.php'>PHP+SESSION防止表單重複提交</a>"; } }
php 解決表單重複提交實現方法介紹
[導讀] 重複提交是我們開發中會常碰到的一個問題,除了我們使用js來防止表單的重複提交,同時還可以使用php來防止重複提交哦。
例1 代碼如下
重複提交是我們開發中會常碰到的一個問題,除了我們使用js來防止表單的重複提交,同時還可以使用php來防止重複提交哦。
例1
代碼如下
<?php /* * php中如何防止表單的重複提交 */session_start(); if (empty($_SESSION['ip'])) {//第一次寫入操作,判斷是否記錄了IP地址,以此知道是否要寫入資料庫 $_SESSION['ip'] = $_SERVER['REMOTE_ADDR']; //第一次寫入,為後面重新整理或後退的判斷做個鋪墊 //...........//寫入資料庫操作} else {//已經有第一次寫入後的操作,也就不再寫入資料庫 echo '請不要再次重新整理和後退'; //寫一些已經寫入的提示或其它東西} ?>
具體原理
session範圍變數token來防止。
1. 開啟session:
session_start();
2. 如果有表單提交
代碼如下 複製代碼
if (isset($token))
token以hidden的形式包含在form當中。
代碼如下 複製代碼
<input type="hidden" name="token" value="<?php echo $token; ?>" />
3. 如果是重複提交表單
代碼如下
if ($_SESSION["token"] != $token) { // 不讓重複提交,在此處理 // header("location:".$_SERVER['PHP_SELF']); } else { // 正常的表單提交,在此處理 // echo "已提交"; }
4. 設定token值
代碼如下
$token = mt_rand(0,1000000);$_SESSION['token'] = $token;
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
推薦閱讀:
PHP實現大檔案切割與合并步驟詳解
PHP+mongoDB資料庫操作步驟詳解