Posted in PHP onNovember 03, 2014
PHP过滤提交表单的html代码里可能有被利用引入外部危险内容的代码。例如,有些时候用户提交表单中含有html内容,但这可能造成显示页面布局混乱,需要过滤掉。
方法一:
//get post data function PostGet($str,$post=0) { empty($str)?die('para is null'.$str.'!'):''; if( $post ) { if( get_magic_quotes_gpc() ) { return htmlspecialchars(isset($_POST[$str])?$_POST [$str]:''); } else { return addslashes(htmlspecialchars(isset($_POST[$str])? $_POST[$str]:'')); } } else { if( get_magic_quotes_gpc() ) { return htmlspecialchars(isset($_GET[$str])?$_GET[$str]:''); } else { return addslashes(htmlspecialchars(isset($_GET[$str])? $_GET[$str]:'')); } } }
方法二:
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; }
很实用的方法吧,希望对大家能有所帮助
php过滤表单提交的html等危险代码
- Author -
hebedich声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@