>  기사  >  백엔드 개발  >  악의적인 페이지 새로 고침을 방지하는 PHP 코드

악의적인 페이지 새로 고침을 방지하는 PHP 코드

WBOY
WBOY원래의
2016-07-25 09:03:371047검색
  1. session_start();
  2. $k=$_GET['k'];
  3. $t=$_GET['t'];
  4. $allowTime = 1800;//防刷新时间
  5. $ip = get_client_ip();
  6. $allowT = md5($ip.$k.$t);
  7. if(!isset($_SESSION[$allowT]))
  8. {
  9. $refresh = true;
  10. $_SESSION[$allowT] = time();
  11. }elseif(time() - $_SESSION[$allowT]>$allowTime){
  12. $refresh = true;
  13. $_SESSION[$allowT] = time();
  14. }else{
  15. $refresh = false;
  16. }
  17. ?>
复制代码

ie6提交两次我也碰到过,大致是用图片代替submit时,图片上有个submit(),这样会提交两次,如果只是submit钮我没碰到过提交两次的情况。

现在整理一下: 方法基本上前面几位说得差不多 接收的页即2.php分为两部分,一部分处理提交过来的变量,一部分显示页面 处理变量完毕用header( "location: ".$_SERVER[ 'PHP_SELF '])跳转到自身页 本部分要做判断,如果没有post的变量就跳过。当然也可以跳到别的页面。 跳到别的页面返回时会有问题,建议做在一个php文件里。 如果上页穿过来得变量不符合要求可以强制返回

  1. <script></li> <li>history.go(-1);</li> <li></script>
复制代码

大体的思路。 2.php的流程

  1. if(isset($_POST))
  2. { 接收变量
  3. if(变量不符合要求)
  4. <script> history.go(-1); </script>
  5. else
  6. 操作数据
  7. ...
  8. if(操作完成)
  9. header( "location: ".$_SERVER[ 'PHP_SELF ']);
  10. }
复制代码


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.