PHP过滤提交表单的html代码里可能有被利用引入外部危险内容的代码。例如,有些时候用户提交表单中含有html内容,但这可能造成显示页面布局混乱,需要过滤掉。
方法一:
<br />//get post data<br /> function PostGet($str,$post=0)<br /> {<br /> empty($str)?die('para is null'.$str.'!'):'';<br /> <br /> if( $post ) <br /> {<br /> if( get_magic_quotes_gpc() )<br /> {<br /> return htmlspecialchars(isset($_POST[$str])?$_POST<br />[$str]:'');<br /> }<br /> else<br /> {<br /> return addslashes(htmlspecialchars(isset($_POST[$str])?<br />$<span>@本文来*源gaodai#ma#com搞*!代#%^码$网*</span><textarea>搞gaodaima代码</textarea>_POST[$str]:''));<br /> }<br /> <br /> }<br /> else<br /> {<br /> if( get_magic_quotes_gpc() )<br /> {<br /> return htmlspecialchars(isset($_GET[$str])?$_GET[$str]:''); <br /> }<br /> else<br /> {<br /> return addslashes(htmlspecialchars(isset($_GET[$str])?<br />$_GET[$str]:'')); <br /> }<br /> }<br /> }<br />
方法二:
<br />function uhtml($str) <br />{ <br /> $farr = array( <br /> "/\s+/", //过滤多余空白 <br /> //过滤 <script>等可能引入恶意内容或恶意改变显示布局的代码,如果不需要插入flash等,还可以加入的过滤 <br /> "/]*?)>/isU", <br /> "/(]*)on[a-zA-Z]+\s*=([^>]*>)/isU",//过滤javascript的on事件 <br /> ); <br /> $tarr = array( <br /> " ", <br /> "<\1\2\3>",//如果要直接清除不安全的标签,这里可以留空 <br /> "\1\2", <br /> ); <br /> $str = preg_replace( $farr,$tarr,$str); <br /> return $str; <br />} <br />
很实用的方法吧,希望对大家能有所帮助