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 静态变量与自定义常量的使用方法
Jan 26 PHP
第4章 数据处理-php正则表达式-郑阿奇(续)
Jul 04 PHP
php 获取页面中指定内容的实现类
Jan 23 PHP
PHP常用技术文之文件操作和目录操作总结
Sep 27 PHP
PHP函数实现分页含文本分页和数字分页
Oct 23 PHP
php面向对象中static静态属性和静态方法的调用
Feb 08 PHP
Laravel5中contracts详解
Mar 02 PHP
php中smarty模板条件判断用法实例
Jun 11 PHP
简单介绍win7下搭建apache+php+mysql开发环境
Aug 06 PHP
基于php实现七牛抓取远程图片
Dec 01 PHP
phpStudy 2016 使用教程详解(支持PHP7)
Oct 18 PHP
PHP7 新增常量
Mar 09 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
一个用mysql_odbc和php写的serach数据库程序
2006/10/09 PHP
phpfans留言版用到的install.php
2007/01/04 PHP
php生成二维码时出现中文乱码的解决方法
2014/12/18 PHP
php实现数组按指定KEY排序的方法
2015/03/30 PHP
PHP GD库相关图像生成和处理函数小结
2016/09/30 PHP
php ajax confirm 删除实例详解
2019/03/06 PHP
测试JavaScript字符串处理性能的代码
2009/12/07 Javascript
Chrome中JSON.parse的特殊实现
2011/01/12 Javascript
基于Jquery的$.cookie()实现跨越页面tabs导航实现代码
2011/03/03 Javascript
Jquery实现搜索框提示功能示例代码
2013/08/13 Javascript
javascript实现获取cookie过期时间的变通方法
2014/08/14 Javascript
你知道setTimeout是如何运行的吗?
2016/08/16 Javascript
jQuery实现简单漂亮的Nav导航菜单效果
2017/03/29 jQuery
javaScript中封装的各种写法示例(推荐)
2017/07/03 Javascript
js获取元素的偏移量offset简单方法(必看)
2017/07/05 Javascript
Vue.js结合Ueditor富文本编辑器的实例代码
2017/07/11 Javascript
js前端导出Excel的方法
2017/11/01 Javascript
详解Eslint 配置及规则说明
2018/09/10 Javascript
为什么说JavaScript预解释是一种毫无节操的机制详析
2018/11/18 Javascript
nuxt.js中间件实现拦截权限判断的方法
2018/11/21 Javascript
小程序富文本提取图片可放大缩小
2020/05/26 Javascript
vue-quill-editor的使用及个性化定制操作
2020/08/04 Javascript
Python splitlines使用技巧
2008/09/06 Python
python的paramiko模块实现远程控制和传输示例
2017/10/13 Python
对python内置map和six.moves.map的区别详解
2018/12/19 Python
Python Web版语音合成实例详解
2019/07/16 Python
python 实现字符串下标的输出功能
2020/02/13 Python
Python基于百度AI实现OCR文字识别
2020/04/02 Python
学校党员对照检查材料
2014/08/28 职场文书
2016自主招生教师推荐信范文
2015/03/23 职场文书
2015年组织部工作总结
2015/04/03 职场文书
2015年林业工作总结
2015/05/14 职场文书
安全教育培训心得体会
2016/01/15 职场文书
2016个人先进事迹材料范文
2016/03/01 职场文书
喜迎建国70周年:有关爱国的名言名句
2019/09/24 职场文书
JS前端可视化canvas动画原理及其推导实现
2022/08/05 Javascript