用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php 防跨站攻击测试例子

时间:2015-01-23  来源:西部数据  作者:西部数据

跨站攻击就是利用程序上的一些细节或bug问题进行的了,那么我们要如何防止跨站攻击呢?下面我们费话不说多了来给大家整理一个防止跨站攻击例子,希望对各位有帮助.

php 防跨站攻击测试例子代码如下:

  1. <?php 
  2. #demo for prevent csrf 
  3.  
  4. /** 
  5. * enc 
  6. */ 
  7. function encrypt($token_time) { 
  8. return md5(‘!@##$@$$#%43′ . $token_time); 
  9.  
  10. $token_time = time(); 
  11. $token = encrypt($token_time); 
  12. $expire_time = 10; 
  13.  
  14. if ($_POST) { 
  15. $_token_time = $_POST['token_time']; 
  16. $_token = $_POST['token']; 
  17.  
  18. if ((time() – $_token_time) > $expire_time) { 
  19. echo “expired token”; 
  20. echo “<br />”; 
  21.  
  22. echo $_token
  23. echo “<br />”; 
  24. $_token_real = encrypt($_token_time); 
  25.  
  26. echo $_token_real
  27. //compare $_token and $_token_real 
  28. ?> 
  29.  
  30. <!DOCTYPE html> 
  31. <html> 
  32. <head> 
  33. <meta http-equiv=”content-type” content=”text/html; charset=utf-8″ /> 
  34. <title>test for csrf</title> 
  35. <meta http-equiv=”" content=”" /> 
  36. </head> 
  37. <body> 
  38. <form method=”post” action=”"> 
  39. <input type=”text” name=”text” id=”" value=”hello” /> 
  40. <input type=”hidden” name=”token” id=”" value=”<?php echo $token ?>” /> 
  41. <input type=”hidden” name=”token_time” id=”" value=”<?php echo $token_time ?>” /> 
  42. //开源代码phpfensi.com 
  43. <input type=”submit” name=”submit” id=”" value=”submit” /> 
  44. </form> 
  45. </body> 
  46. </html> 

通过在你的表单中包括验证码,事实上已经消除了跨站请求伪造攻击的风险,可以在任何需要执行操作的任何表单中使用这个流程,当然,将token 存储到session更好,这儿只是简单示例下.

简单分析:token防攻击也叫作(令牌)了,我们在用户访问页面时就生成了一个随机的token保存session与表单了,用户提交时如果我们获取到的token与session不一样就可以提交重新输入提交数据了.

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门