PHP过滤提交表单的html代码里可能有被利用引入外部危险内容的代码。例如,有些时候用户提交表单中含有html内容,但这可能造成显示页面布局混乱,需要过滤掉。
- function uhtml($str)
- {
- $farr = array(
- "/\s+/", //过滤多余空白
- //过滤 <script>等可能引入恶意内容或恶意改变显示布局的代码,如果不需要插入flash等,还可以加入<object>的过滤 <li> "/<(\/?)(script|i?frame|style|html|body|title|link|meta|\?|\%)([^>]*?)>/isU", <li> "/(<[^>]*)on[a-zA-Z]+\s*=([^>]*>)/isU",//过滤javascript的on事件 <li> ); <li> $tarr = array( <li> " ", <li> "<\1\2\3>",//如果要直接清除不安全的标签,这里可以留空 <li> "\1\2", <li> ); <li> $str = preg_replace( $farr,$tarr,$str); <li> return $str; <li>}</script>
复制代码
|