PHP过滤HTML字符串函数详解(2)
来源:未知 责任编辑:责任编辑 发表时间:2013-11-15 19:50 点击:次
//取得所有要处理的标记
$pattern = "/<$tag(.*)</$tag>/i";
preg_match_all($pattern,$str,$out);
//循环处理每个标记
foreach($out[1] as $key => $val) {
//取得a标记中有几个=
$cnt = preg_split(/ *=/i,$val);
$cnt = count($cnt) -1;
//构造匹配正则
$pattern = ;
for($i=1; $i<=$cnt; $i ) {
$pattern .= ( .*=.*);
}
//完成正则表达式形成,如/(<a)( .*=.*)( .*=.*)(>.*</a>/i的样式
$pattern = "/(<$tag)$pattern(>.*</$tag>)/i";
//取得保留属性
$replacement = match($pattern,$out[0][$key],$keep_attribute);
//替换
$str = str_replace($out[0][$key],$replacement,$str);
}
}
/**
* 说明:构造标签,保留要保留的属性
* 参数:$reg : pattern,preg_match的表达式
* $str : string,html字串
* $arr : array,要保留的属性
* 返回:
* 返回经保留处理后的标签,如
* <A href=http://www.e.com target=_blank alt=e e e>e.com</A>
*/
function match($reg,&$str,$arr) {
//match
preg_match($reg,$str,$out);
//取出保留的属性
$keep_attribute = ;
foreach($arr as $k1=>$v1) {
//定义的要保留的属性的数组
foreach($out as $k2=>$v2) {
//匹配=后的数组
$attribute = trim(substr($v2,0,strpos($v2,=)));
//=前面的
if($v1 == $attribute) {
//要保留的属性和匹配的值的=前的部分相同
$keep_attribute .= $v2;
//保存此匹配部分的值
}
}
}
//构造返回值,结构如:<a href=xxx target=xxx class=xxx>aadd</a>
$keep_attribute = $out[1].$keep_attribute.($out[count($out)-1]);
//返回值
Return $keep_attribute;
}
/**
* 显示字串内容
*/
function show($str,$title=,$debug = True) {
if($debug) {
if(is_array($str)) {
$str = print_r($str,True);
}
$txtRows = count(explode(" ",$str)) 1;
echo($title.:<br><TEXTAREA NAME="txt" ROWS=".$txtRows." COLS="130">.$str.</TEXTAREA><br><br>);
}
}
?>
相关新闻>>
- 发表评论
-
- 最新评论 更多>>