php防止csrf请求

转:http://blog.csdn.net/liutingxu1/article/details/18178783

最近在看php核心技术与开发实践,里面的这段放垃圾机器人刷表单的程序分享一下,自己写了一个简单的表单提交

[php] view plaincopy在CODE上查看代码片派生到我的代码片

  1. <?php
  2. /** 
  3.  * 模拟机器人来发表微博评论 
  4.  */  
  5. define('SECRET''67%$#ap28'); 
  6. function m_token() {  
  7.     $str = mt_rand(1000, 9999);  
  8.     $str2 = dechex($_SERVER['REQUEST_TIME'] - $str);  
  9.     return $str . substr(md5($str . SECRET), 0, 10) . $str2;  

  10. ?>  
  11. <html>  
  12. <meta charset="utf-8">  
  13. <head>  
  14. <title>提交验证</title>  
  15. </head>  
  16. <body>  
  17.     <form action="testcsrf.php" method="post" name="myform">  
  18.         <input name="user" value="" />  
  19.         <input type="submit" name="submit" value="提交" />  
  20.         <input type="hidden" name="token" value="<?php echo m_token();?>" />  
  21.     </form>  
  22. </body>  
  23. </html>
  24. testcsrf.php
  25. <?php
  26. define('SECRET''67%$#ap28');
  27. function v_token($str$delay = 10) {  
  28.     $rs = substr($str, 0, 4);   
  29.     $middle = substr($str, 0, 14);  
  30.     $rs2 = substr($str, 14, 8);   
  31.     return ($middle == $rs.substr(md5($rs.SECRET), 0, 10)) &&    
  32.         ($_SERVER['REQUEST_TIME'] - hexdec($rs2) - $rs < $delay);  
  33. }
  34. if(v_token($_POST["token"])){
  35.     echo "right";
  36. }else{
  37.     echo "error";
  38. }
  39. ?>  
  40. 上面这段代码也可以用作防止csrf攻击。
  41.  

    A+
发布日期:2014年09月08日  所属分类:未分类

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: