首先分享一些比较常见的
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
$str =preg_replace( "/<s*imgs+[^>]*?srcs*=s*('|" )(.*?)\1[^>]*?/?s*>/i "," ", $str ); //过滤img标签
$str =preg_replace( "/s+/" , "" , $str ); //过滤多余回车
$str =preg_replace( "/<[ ]+/si" , "<" , $str ); //过滤<__("<"号后面带空格)
$str =preg_replace( "/<!--.*?-->/si" , "" , $str ); //注释
$str =preg_replace( "/<(!.*?)>/si" , "" , $str ); //过滤DOCTYPE
$str =preg_replace( "/<(/?html.*?)>/si" , "" , $str ); //过滤html标签
$str =preg_replace( "/<(/?head.*?)>/si" , "" , $str ); //过滤head标签
$str =preg_replace( "/<(/?meta.*?)>/si" , "" , $str ); //过滤meta标签
$str =preg_replace( "/<(/?body.*?)>/si" , "" , $str ); //过滤body标签
$str =preg_replace( "/<(/?link.*?)>/si" , "" , $str ); //过滤link标签
$str =preg_replace( "/<(/?form.*?)>/si" , "" , $str ); //过滤form标签
$str =preg_replace( "/cookie/si" , "COOKIE" , $str ); //过滤COOKIE标签
$str =preg_replace( "/<(applet.*?)>(.*?)<(/applet.*?)>/si" , "" , $str ); //过滤applet标签
$str =preg_replace( "/<(/?applet.*?)>/si" , "" , $str ); //过滤applet标签
$str =preg_replace( "/<(style.*?)>(.*?)<(/style.*?)>/si" , "" , $str ); //过滤style标签
$str =preg_replace( "/<(/?style.*?)>/si" , "" , $str ); //过滤style标签
$str =preg_replace( "/<(title.*?)>(.*?)<(/title.*?)>/si" , "" , $str ); //过滤title标签
$str =preg_replace( "/<(/?title.*?)>/si" , "" , $str ); //过滤title标签
$str =preg_replace( "/<(object.*?)>(.*?)<(/object.*?)>/si" , "" , $str ); //过滤object标签
$str =preg_replace( "/<(/?objec.*?)>/si" , "" , $str ); //过滤object标签
$str =preg_replace( "/<(noframes.*?)>(.*?)<(/noframes.*?)>/si" , "" , $str ); //过滤noframes标签
$str =preg_replace( "/<(/?noframes.*?)>/si" , "" , $str ); //过滤noframes标签
$str =preg_replace( "/<(i?frame.*?)>(.*?)<(/i?frame.*?)>/si" , "" , $str ); //过滤frame标签
$str =preg_replace( "/<(/?i?frame.*?)>/si" , "" , $str ); //过滤frame标签
$str =preg_replace( "/<(script.*?)>(.*?)<(/script.*?)>/si" , "" , $str ); //过滤script标签
$str =preg_replace( "/<(/?script.*?)>/si" , "" , $str ); //过滤script标签
$str =preg_replace( "/javascript/si" , "Javascript" , $str ); //过滤script标签
$str =preg_replace( "/vbscript/si" , "Vbscript" , $str ); //过滤script标签
$str =preg_replace( "/on([a-z]+)s*=/si" , "On\1=" , $str ); //过滤script标签
$str =preg_replace( "/&#/si" , "&#" , $str ); //过滤script标签
|
更简单些的写法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
function delhtml( $str ){ //清除html标签
$st =-1; //开始
$et =-1; //结束
$stmp = array ();
$stmp []= " " ;
$len = strlen ( $str );
for ( $i =0; $i < $len ; $i ++){
$ss = substr ( $str , $i ,1);
if (ord( $ss )==60){ //ord("<")==60
$st = $i ;
}
if (ord( $ss )==62){ //ord(">")==62
$et = $i ;
if ( $st !=-1){
$stmp []= substr ( $str , $st , $et - $st +1);
}
}
}
$str = str_replace ( $stmp , "" , $str );
return $str ;
}
|
再来一个:
1
2
3
4
5
6
|
function clear_html_label( $html )
{
$search = array ( "'<script[^>]*?>.*?</script>'si" , "'<[/!]*?[^<>]*?>'si" , "'([rn])[s]+'" , "'&(quot|#34);'i" , "'&(amp|#38);'i" , "'&(lt|#60);'i" , "'&(gt|#62);'i" , "'&(nbsp|#160);'i" , "'&(iexcl|#161);'i" , "'&(cent|#162);'i" , "'&(pound|#163);'i" , "'&(copy|#169);'i" , "'&#(d+);'e" );
$replace = array ( "" , "" , "1" , "" ", " & ", " < ", " > ", " ", chr(161), chr(162), chr(163), chr(169), " chr (1)");
return preg_replace( $search , $replace , $html );
}
|
以上三种方法均可以实现,不过各有优劣,小伙伴们根据自己的项目需求来选择吧。