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 代碼如下復制代碼
例1
代碼如下 | 復制代碼 |
<?php |
具體原理
session范圍變量token來防止。
1. 開啟session:
session_start();
2. 如果有表單提交
代碼如下 | 復制代碼 |
if (isset($token)) |
token以hidden的形式包含在form當中。
代碼如下 | 復制代碼 |
<input type="hidden" name="token" value="<?php echo $token; ?>" /> |
3. 如果是重復提交表單
代碼如下 | 復制代碼 |
1.if ($_SESSION["token"] != $token) { |
4. 設置token值
代碼如下 | 復制代碼 |
1.$token = mt_rand(0,1000000); |