PHP+Session을 사용하여 반복적인 양식 제출을 방지하는 단계에 대한 자세한 설명

php中世界最好的语言
풀어 주다: 2023-03-26 08:16:01
원래의
2509명이 탐색했습니다.

이번에는 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[&#39;submit&#39;])) { 
  if ($_SESSION[&#39;is_submit&#39;] == &#39;0&#39;) { 
    $_SESSION[&#39;is_submit&#39;] = &#39;1&#39;; 
    echo "代码块,要做的事,代码...<a onclick=&#39;history.go(-1);&#39; href=&#39;javascript:void(0)&#39;>返回</a>"; 
  } else { 
    echo "请不用重复提交<a href=&#39;index.php&#39;>PHP+SESSION防止表单重复提交</a>"; 
  } 
}
로그인 후 복사

양식의 반복 제출 문제를 해결하기 위한 PHP 소개

[소개] 반복 제출은 반복 제출을 방지하기 위해 js를 사용하는 것 외에도 개발에서 자주 발생하는 문제입니다. 양식을 제출하려면 PHP를 사용하여 중복을 방지할 수도 있습니다.

예제 1 코드는 다음과 같습니다

중복 제출은 개발 중에 자주 발생하는 문제입니다. js를 사용하여 양식의 반복 제출을 방지하는 것 외에도 PHP를 사용하여 반복 제출을 방지할 수도 있습니다.

예제1

코드는 다음과 같습니다

<?php
 /*
 * php中如何防止表单的重复提交
 */
session_start();
 if (empty($_SESSION[&#39;ip&#39;])) {//第一次写入操作,判断是否记录了IP地址,以此知道是否要写入数据库
  $_SESSION[&#39;ip&#39;] = $_SERVER[&#39;REMOTE_ADDR&#39;]; //第一次写入,为后面刷新或后退的判断做个铺垫
  //...........//写入数据库操作
} else {//已经有第一次写入后的操作,也就不再写入数据库
  echo &#39;请不要再次刷新和后退&#39;; //写一些已经写入的提示或其它东西
}
 ?>
로그인 후 복사

구체적인 원리

세션 범위 변수 토큰을 방지합니다.

1. 세션 열기:

session_start();session_start();

2. 如果有表单提交

代码如下 复制代码

if (isset($token))

2. 양식 제출이 있는 경우

코드는 다음과 같습니다. 코드를 복사하세요

if (isset($ token))

토큰은 숨겨진 형태로 양식에 포함됩니다.

다음과 같이 코드를 복사하세요

<input type="hidden" name="token" value="<?php echo $token; ?>" />
로그인 후 복사

3. 양식을 반복해서 제출하는 경우

코드는 다음과 같습니다

if ($_SESSION["token"] != $token) { 
  // 不让重复提交,在此处理 
  // header("location:".$_SERVER[&#39;PHP_SELF&#39;]); 
 } else { 
  // 正常的表单提交,在此处理 
  // echo "已提交";  
}
로그인 후 복사

4. 토큰 값을 설정하세요

코드는 다음과 같습니다

$token = mt_rand(0,1000000);
$_SESSION[&#39;token&#39;] = $token;
로그인 후 복사
마스터하신 것 같습니다. 본 글의 사례를 읽어보신 후, 더 흥미로운 정보를 보시려면 오시기 바랍니다. PHP 중국어 사이트의 다른 관련 글도 주목해주세요!
추천 도서:

PHP

PHP+mongoDB 데이터베이스 작업 단계에 대한 자세한 설명

php 중국어 웹사이트 학습 주제🎜: 🎜php 세션 🎜 (사진 및 텍스트 포함) , 동영상, 케이스)🎜🎜

위 내용은 PHP+Session을 사용하여 반복적인 양식 제출을 방지하는 단계에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿