PHP 防止表單重複提交
阿新 • • 發佈:2020-11-23
<?php /* * PHP簡單利用token防止表單重複提交 * 此處理方法純粹是為了給初學者參考 */ session_start(); var_dump($_POST); function set_token() { $_SESSION['token'] = md5(microtime(true)); var_dump($_SESSION['token']); } function valid_token() { $return = $_REQUEST['token'] === $_SESSION['token'] ? true : false; set_token(); return $return; } //如果token為空則生成一個token if(!isset($_SESSION['token']) || $_SESSION['token']=='') { set_token(); } if(isset($_POST['test'])){ if(!valid_token()){ echo "token error"; }else{ echo '成功提交,Value:'.$_POST['test']; } } ?> <form method="post" action=""> <input type="hidden" name="token" value="<?php echo $_SESSION['token']?>"> <input type="text" name="test" value="Default"> <input type="submit" value="提交" /> </form>