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 相关文章推荐
使用 MySQL Date/Time 类型
Mar 26 PHP
php 数组使用详解 推荐
Jun 02 PHP
php中使用Imagick实现图像直方图的实现代码
Aug 30 PHP
PHP实现时间轴函数代码
Oct 08 PHP
PHP中Fatal error session_start()错误解决步骤
Aug 05 PHP
php中异常处理方法小结
Jan 09 PHP
PHP、Python和Javascript的装饰器模式对比
Feb 03 PHP
PHP处理会话函数大总结
Aug 05 PHP
ThinkPHP3.2.2实现持久登录(记住我)功能的方法
May 16 PHP
php array_key_exists() 与 isset() 的区别
Oct 24 PHP
php 浮点数比较方法详解
May 05 PHP
PHP 计算两个时间段之间交集的天数示例
Oct 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
PHPMyadmin 配置文件详解(配置)
2009/12/03 PHP
PHP ? EasyUI DataGrid 资料取的方式介绍
2012/11/07 PHP
深入理解PHP中的Session和Cookie
2013/06/21 PHP
php stripslashes和addslashes的区别
2014/02/03 PHP
PHP生成二维码的两个方法和实例
2014/07/01 PHP
ThinkPHP中自定义目录结构的设置方法
2014/08/15 PHP
php导出csv文件,可导出前导0实例代码
2016/11/16 PHP
7个Javascript地图脚本整理
2009/10/20 Javascript
js本身的局限性 别让javascript做太多事
2010/03/23 Javascript
如何在MVC应用程序中使用Jquery
2014/11/17 Javascript
详解JavaScript实现设计模式中的适配器模式的方法
2016/05/18 Javascript
Bootstrap布局组件教程之Bootstrap下拉菜单
2016/06/12 Javascript
Vue-cli创建项目从单页面到多页面的方法
2017/09/20 Javascript
angular4中关于表单的校验示例
2017/10/16 Javascript
ActiveX控件的使用-js实现打印超市小票功能代码详解
2017/11/22 Javascript
react-native封装插件swiper的使用方法
2018/03/20 Javascript
AngularJS 多指令Scope问题的解决
2018/10/25 Javascript
原生JS实现的自动轮播图功能详解
2018/12/28 Javascript
使用vue-cli脚手架工具搭建vue-webpack项目
2019/01/14 Javascript
JavaScript迭代器的含义及用法
2019/06/21 Javascript
vue使用nprogress实现进度条
2019/12/09 Javascript
python用于url解码和中文解析的小脚本(python url decoder)
2013/08/11 Python
Python中optionParser模块的使用方法实例教程
2014/08/29 Python
Python中将字典转换为XML以及相关的命名空间解析
2015/10/15 Python
浅谈Python实现2种文件复制的方法
2018/01/19 Python
Python实现的三层BP神经网络算法示例
2018/02/07 Python
Python中new方法的详解
2019/01/15 Python
使用Python控制摄像头拍照并发邮件
2019/04/23 Python
Python Selenium库的基本使用教程
2021/01/04 Python
python实现图片转字符画
2021/02/19 Python
电子商务专业自我鉴定
2013/12/18 职场文书
五一劳动节演讲稿
2014/09/12 职场文书
民政局个人整改措施
2014/09/24 职场文书
你会写请假条吗?
2019/06/26 职场文书
解决Pytorch修改预训练模型时遇到key不匹配的情况
2021/06/05 Python
帮你提高开发效率的JavaScript20个技巧
2021/06/18 Javascript