返回顶部

收藏

用php过滤表单提交中的危险html代码

更多

PHP过滤提交表单的html代码里可能有被利用引入外部危险内容的代码。例如,有些时候用户提交表单中含有html内容,但这可能造成显示页面布局混乱,需要过滤掉 。

function uhtml($str)  
{  
    $farr = array(  
        "/\\s+/", //过滤多余空白  
         //过滤 <script>等可能引入恶意内容或恶意改变显示布局的代码,如果不需要插入flash等,还可以加入<object>的过滤  
        "/<(\\/?)(script|i?frame|style|html|body|title|link|meta|\\?|\\%)([^>]*?)>/isU", 
        "/(<[^>]*)on[a-zA-Z]+\\s*=([^>]*>)/isU",//过滤javascript的on事件  
   );  
   $tarr = array(  
        " ",  
        "<\\1\\2\\3>",//如果要直接清除不安全的标签,这里可以留空  
        "\\1\\2",  
   );  
  $str = preg_replace( $farr,$tarr,$str);  
   return $str;  
}
//该片段来自于http://outofmemory.cn

标签:php,安全

收藏

0人收藏

支持

0

反对

0

发表评论