当前位置:首页 > PHP教程 > php应用 > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-04-21 11:08:36 浏览: 评论:0 

表单提交如果安全做得不好就很容易因为这个表单提交导致网站被攻击了,下面我来分享两个常用的php过滤表单提交的危险代码的实例,各位有需要的朋友可参考。

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

方法一:

  1. //get post data 
  2.  function PostGet($str,$post=0) 
  3.  { 
  4.   emptyempty($str)?die('para is null'.$str.'!'):''
  5.  
  6.   if$post ) 
  7.   { 
  8.    if( get_magic_quotes_gpc() ) 
  9.    { 
  10.     return htmlspecialchars(isset($_POST[$str])?$_POST 
  11. [$str]:''); 
  12.    } 
  13.    else 
  14.    { 
  15.     return addslashes(htmlspecialchars(isset($_POST[$str])? 
  16. $_POST[$str]:'')); 
  17.    } 
  18.    
  19.   } 
  20.   else 
  21.   { 
  22.    if( get_magic_quotes_gpc() ) 
  23.    { 
  24.     return htmlspecialchars(isset($_GET[$str])?$_GET[$str]:''); 
  25.    } 
  26.    else 
  27.    { 
  28.     return addslashes(htmlspecialchars(isset($_GET[$str])? 
  29. $_GET[$str]:'')); 
  30.    } 
  31.   } 
  32.  } 

方法二:

  1. function uhtml($str)     
  2. {     
  3.     $farr = array(     
  4.         "/\s+/"//过滤多余空白     
  5.          //过滤 <script>等可能引入恶意内容或恶意改变显示布局的代码,如果不需要插入flash等,还可以加入<object>的过滤     
  6.         "/<(\/?)(script|i?frame|style|html|body|title|link|meta|\?|\%)([^>]*?)>/isU",    
  7.         "/(<[^>]*)on[a-zA-Z]+\s*=([^>]*>)/isU",//过滤javascript的on事件     
  8.    );     
  9.    $tarr = array(     
  10.         " ",     
  11.         "<\1\2\3>",//如果要直接清除不安全的标签,这里可以留空     
  12.         "\1\2",     
  13.    );    //www.phpfensi.com 
  14.   $str = preg_replace( $farr,$tarr,$str);     
  15.    return $str;     
  16. }  

很实用的方法吧,希望对大家能有所帮助

Tags: php过滤表单

分享到: