php实现XSS安全过滤的方法


Posted in PHP onJuly 29, 2015

本文实例讲述了php实现XSS安全过滤的方法。分享给大家供大家参考。具体如下:

function remove_xss($val) {
  // remove all non-printable characters. CR(0a) and LF(0b) and TAB(9) are allowed
  // this prevents some character re-spacing such as <java\0script>
  // note that you have to handle splits with \n, \r, and \t later since they *are* allowed in some inputs
  $val = preg_replace('/([\x00-\x08,\x0b-\x0c,\x0e-\x19])/', '', $val);
  // straight replacements, the user should never need these since they're normal characters
  // this prevents like <IMG SRC=@avascript:alert('XSS')>
  $search = 'abcdefghijklmnopqrstuvwxyz';
  $search .= 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
  $search .= '1234567890!@#$%^&*()';
  $search .= '~`";:?+/={}[]-_|\'\\';
  for ($i = 0; $i < strlen($search); $i++) {
   // ;? matches the ;, which is optional
   // 0{0,7} matches any padded zeros, which are optional and go up to 8 chars
   // @ @ search for the hex values
   $val = preg_replace('/(&#[xX]0{0,8}'.dechex(ord($search[$i])).';?)/i', $search[$i], $val); // with a ;
   // @ @ 0{0,7} matches '0' zero to seven times
   $val = preg_replace('/(�{0,8}'.ord($search[$i]).';?)/', $search[$i], $val); // with a ;
  }
  // now the only remaining whitespace attacks are \t, \n, and \r
  $ra1 = array('javascript', 'vbscript', 'expression', 'applet', 'meta', 'xml', 'blink', 'link', 'style', 'script', 'embed', 'object', 'iframe', 'frame', 'frameset', 'ilayer', 'layer', 'bgsound', 'title', 'base');
  $ra2 = array('onabort', 'onactivate', 'onafterprint', 'onafterupdate', 'onbeforeactivate', 'onbeforecopy', 'onbeforecut', 'onbeforedeactivate', 'onbeforeeditfocus', 'onbeforepaste', 'onbeforeprint', 'onbeforeunload', 'onbeforeupdate', 'onblur', 'onbounce', 'oncellchange', 'onchange', 'onclick', 'oncontextmenu', 'oncontrolselect', 'oncopy', 'oncut', 'ondataavailable', 'ondatasetchanged', 'ondatasetcomplete', 'ondblclick', 'ondeactivate', 'ondrag', 'ondragend', 'ondragenter', 'ondragleave', 'ondragover', 'ondragstart', 'ondrop', 'onerror', 'onerrorupdate', 'onfilterchange', 'onfinish', 'onfocus', 'onfocusin', 'onfocusout', 'onhelp', 'onkeydown', 'onkeypress', 'onkeyup', 'onlayoutcomplete', 'onload', 'onlosecapture', 'onmousedown', 'onmouseenter', 'onmouseleave', 'onmousemove', 'onmouseout', 'onmouseover', 'onmouseup', 'onmousewheel', 'onmove', 'onmoveend', 'onmovestart', 'onpaste', 'onpropertychange', 'onreadystatechange', 'onreset', 'onresize', 'onresizeend', 'onresizestart', 'onrowenter', 'onrowexit', 'onrowsdelete', 'onrowsinserted', 'onscroll', 'onselect', 'onselectionchange', 'onselectstart', 'onstart', 'onstop', 'onsubmit', 'onunload');
  $ra = array_merge($ra1, $ra2);
  $found = true; // keep replacing as long as the previous round replaced something
  while ($found == true) {
   $val_before = $val;
   for ($i = 0; $i < sizeof($ra); $i++) {
     $pattern = '/';
     for ($j = 0; $j < strlen($ra[$i]); $j++) {
      if ($j > 0) {
        $pattern .= '(';
        $pattern .= '(&#[xX]0{0,8}([9ab]);)';
        $pattern .= '|';
        $pattern .= '|(�{0,8}([9|10|13]);)';
        $pattern .= ')*';
      }
      $pattern .= $ra[$i][$j];
     }
     $pattern .= '/i';
     $replacement = substr($ra[$i], 0, 2).'<x>'.substr($ra[$i], 2); // add in <> to nerf the tag
     $val = preg_replace($pattern, $replacement, $val); // filter out the hex tags
     if ($val_before == $val) {
      // no replacements were made, so exit the loop
      $found = false;
     }
   }
  }
  return $val;
}

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
php不用正则采集速度探究总结
Mar 24 PHP
PHP 开发环境配置(Zend Server安装)
Apr 28 PHP
php随机输出名人名言的代码
Oct 07 PHP
基于Linux调试工具strace与gdb的常用命令总结
Jun 03 PHP
基于PHP CURL用法的深入分析
Jun 09 PHP
解析php file_exists无效的解决办法
Jun 26 PHP
file_get_contents(&quot;php://input&quot;, &quot;r&quot;)实例介绍
Jul 01 PHP
PHP自定session保存路径及删除、注销与写入的方法
Nov 18 PHP
PHP使用glob方法遍历文件夹下所有文件的实例
Oct 17 PHP
laravel 框架配置404等异常页面
Jan 07 PHP
PHP类的自动加载机制实现方法分析
Jan 10 PHP
php设计模式之正面模式实例分析【星际争霸游戏案例】
Mar 24 PHP
php检查字符串中是否有外链的方法
Jul 29 #PHP
php数组比较实现查找连续数的方法
Jul 29 #PHP
PHP实现XML与数据格式进行转换类实例
Jul 29 #PHP
PHP获取某个月最大天数(最后一天)的方法
Jul 29 #PHP
discuz图片顺序混乱解决方案
Jul 29 #PHP
php计算title标题相似比的方法
Jul 29 #PHP
PHP实现简单实用的验证码类
Jul 29 #PHP
You might like
PHP配置心得包含MYSQL5乱码解决
2006/11/20 PHP
php基础学习之变量的使用
2011/06/09 PHP
编写Smarty插件在模板中直接加载数据的详细介绍
2013/06/26 PHP
DEDECMS首页调用图片集里的多张图片
2015/06/05 PHP
PHP模板引擎Smarty自定义变量调解器用法
2016/04/11 PHP
CodeIgniter框架实现的整合Smarty引擎DEMO示例
2019/03/28 PHP
由JavaScript技术实现的web小游戏(不含网游)
2010/06/12 Javascript
javascript设计模式Constructor(构造器)模式
2016/08/19 Javascript
基于vuejs实现一个todolist项目
2017/04/11 Javascript
详解Vue 动态添加模板的几种方法
2017/04/25 Javascript
如何快速解决JS或Jquery ajax异步跨域的问题
2018/01/08 jQuery
Bootstrap popover 实现鼠标移入移除显示隐藏功能方法
2018/01/24 Javascript
浅谈js闭包理解
2019/03/28 Javascript
react 中父组件与子组件双向绑定问题
2019/05/20 Javascript
Node.js 的 GC 机制详解
2019/06/03 Javascript
详解vue微信网页授权最终解决方案
2019/06/16 Javascript
微信小程序表单验证插件WxValidate的二次封装功能(终极版)
2019/09/03 Javascript
VUE注册全局组件和局部组件过程解析
2019/10/10 Javascript
原生JS实现弹幕效果的简单操作指南
2020/11/10 Javascript
微信小程序tab左右滑动切换功能的实现代码
2021/02/08 Javascript
Python urlopen 使用小示例
2008/09/06 Python
在Python的Flask框架下使用sqlalchemy库的简单教程
2015/04/09 Python
DES加密解密算法之python实现版(图文并茂)
2018/12/06 Python
python reverse反转部分数组的实例
2018/12/13 Python
Python实现截取PDF文件中的几页代码实例
2019/03/11 Python
TensorFlow设置日志级别的几种方式小结
2020/02/04 Python
利用python实现凯撒密码加解密功能
2020/03/31 Python
没编程基础可以学python吗
2020/06/17 Python
巴西最大的家电和百货零售商:Casas Bahia
2016/11/22 全球购物
德国自行车商店:Tretwerk
2019/06/21 全球购物
幼儿园母亲节活动方案
2014/03/10 职场文书
门前三包责任书
2014/04/15 职场文书
庆六一活动总结
2014/08/29 职场文书
2015年教师业务工作总结
2015/05/26 职场文书
优质服务标语口号
2015/12/26 职场文书
Win10 最新稳定版本 21H2开始推送
2022/04/19 数码科技