标签:with alpha 如何 ring pre ret entity lambda 过滤
HTML中<,>,&等有特殊含义(<,>,用于链接签,&用于转义),不能直接使用。这些符号是不显示在我们最终看到的网页里的,那如果我们希望在网页中显示这些符号,该怎么办呢?
这就要说到HTML转义字符串(Escape Sequence)了。
转义字符串(Escape Sequence)也称字符实体(Character Entity)。在HTML中,定义转义字符串的原因有两个:
第一个原因是像“<”和“>”这类符号已经用来表示HTML标签,因此就不能直接当作文本中的符号来使用。为了在HTML文档中使用这些符号,就需要定义它的转义字符串。当解释程序遇到这类字符串时就把它解释为真实的字符。在输入转义字符串时,要严格遵守字母大小写的规则。
第二个原因是,有些字符在ASCII字符集中没有定义,因此需要使用转义字符串来表示。
转义字符串(Escape Sequence),即字符实体(Character Entity)分成三部分:
第一部分是一个&符号,英文叫ampersand;
第二部分是实体(Entity)名字或者是#加上实体(Entity)编号;
第三部分是一个分号。
比如,要显示小于号(<),就可以写 < 或者 < 。
用实体(Entity)名字的好处是比较好理解,一看lt,大概就猜出是less than的意思,但是其劣势在于并不是所有的浏览器都支持最新的Entity名字。而实体(Entity)编号,各种浏览器都能处理。
提示:实体名称(Entity)是区分大小写的。
备注:同一个符号,可以用“实体名称”和“实体编号”两种方式引用,“实体名称”的优势在于便于记忆,但不能保证所有的浏览器都能顺利识别它,而“实体编号”则没有这种担忧,但它实在不方便记忆。
通常情况下,HTML会自动截去多余的空格。不管你加多少空格,都被看做一个空格。比如你在两个字之间加了10个空格,HTML会截去9个空格,只保留一个。为了在网页中增加空格,你可以使用 表示空格。
显示 | 说明 | 实体名称 | 实体编号 |
---|---|---|---|
半方大的空白 |   |   | |
全方大的空白 |   |   | |
不断行的空格 | |   | |
< | 小于 | < | < |
> | 大于 | > | > |
& | &符号 | & | & |
" | 双引号 | " | " |
? | 版权 | © | © |
? | 已注册商标 | ® | ® |
? | 商标(美国) | ? | ™ |
× | 乘号 | × | × |
÷ | 除号 | ÷ | ÷ |
HTML 4.01 支持 ISO 8859-1 (Latin-1) 字符集。
备注:为了方便起见,以下表格中,“实体名称”简称为“名称”,“实体编号”简称为“编号”
显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|   | ? | ¡ | ¡ | ¢ | ¢ | ¢ | £ | £ | £ | ¤ | ¤ | ¤ | |
¥ | ¥ | ¥ | | | ¦ | ¦ | § | § | § | ¨ | ¨ | ¨ | ? | © | © |
a | ª | ª | ? | « | « | ? | ¬ | ¬ | ­ | ­ | ? | ® | ® | |
ˉ | ¯ | ¯ | ° | ° | ° | ± | ± | ± | 2 | ² | ² | 3 | ³ | ³ |
′ | ´ | ´ | μ | µ | µ | ? | ¶ | ¶ | · | · | · | ? | ¸ | ¸ |
1 | ¹ | ¹ | o | º | º | ? | » | » | ? | ¼ | ¼ | ? | ½ | ½ |
? | ¾ | ¾ | ? | ¿ | ¿ | à | À | À | á | Á | Á | ? | Â | Â |
? | Ã | Ã | ? | Ä | Ä | ? | Å | Å | ? | Æ | Æ | ? | Ç | Ç |
è | È | È | é | É | É | ê | Ê | Ê | ? | Ë | Ë | ì | Ì | Ì |
í | Í | Í | ? | Î | Î | ? | Ï | Ï | D | Ð | Ð | ? | Ñ | Ñ |
ò | Ò | Ò | ó | Ó | Ó | ? | Ô | Ô | ? | Õ | Õ | ? | Ö | Ö |
× | × | × | ? | Ø | Ø | ù | Ù | Ù | ú | Ú | Ú | ? | Û | Û |
ü | Ü | Ü | Y | Ý | Ý | T | Þ | Þ | ? | ß | ß | à | à | à |
á | á | á | a | â | â | ? | ã | ã | ? | ä | ä | ? | å | å |
? | æ | æ | ? | ç | ç | è | è | è | é | é | é | ê | ê | ê |
? | ë | ë | ì | ì | ì | í | í | í | ? | î | î | ? | ï | ï |
e | ð | ð | ? | ñ | ñ | ò | ò | ò | ó | ó | ó | ? | ô | ô |
? | õ | õ | ? | ö | ö | ÷ | ÷ | ÷ | ? | ø | ø | ù | ù | ù |
ú | ú | ú | ? | û | û | ü | ü | ü | y | ý | ý | t | þ | þ |
? | ÿ | ÿ |
显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
? | ƒ | ƒ | Α | Α | Α | Β | Β | Β | Γ | Γ | Γ | Δ | Δ | Δ |
Ε | Ε | Ε | Ζ | Ζ | Ζ | Η | Η | Η | Θ | Θ | Θ | Ι | Ι | Ι |
Κ | Κ | Κ | Λ | Λ | Λ | Μ | Μ | Μ | Ν | Ν | Ν | Ξ | Ξ | Ξ |
Ο | Ο | Ο | Π | Π | Π | Ρ | Ρ | Ρ | Σ | Σ | Σ | Τ | Τ | Τ |
Υ | Υ | Υ | Φ | Φ | Φ | Χ | Χ | Χ | Ψ | Ψ | Ψ | Ω | Ω | Ω |
α | α | α | β | β | β | γ | γ | γ | δ | δ | δ | ε | ε | ε |
ζ | ζ | ζ | η | η | η | θ | θ | θ | ι | ι | ι | κ | κ | κ |
λ | λ | λ | μ | μ | μ | ν | ν | ν | ξ | ξ | ξ | ο | ο | ο |
π | π | π | ρ | ρ | ρ | ? | ς | ς | σ | σ | σ | τ | τ | τ |
υ | υ | υ | φ | φ | φ | χ | χ | χ | ψ | ψ | ψ | ω | ω | ω |
? | ϑ | ϑ | ? | ϒ | ϒ | ? | ϖ | ϖ | ? | • | • | … | … | … |
′ | ′ | ′ | ″ | ″ | ″ |  ̄ | ‾ | ‾ | ? | ⁄ | ⁄ | ? | ℘ | ℘ |
? | ℑ | ℑ | ? | ℜ | ℜ | ? | ™ | ™ | ? | ℵ | ℵ | ← | ← | ← |
↑ | ↑ | ↑ | → | → | → | ↓ | ↓ | ↓ | ? | ↔ | ↔ | ? | ↵ | ↵ |
? | ⇐ | ⇐ | ? | ⇑ | ⇑ | ? | ⇒ | ⇒ | ? | ⇓ | ⇓ | ? | ⇔ | ⇔ |
? | ∀ | ∀ | ? | ∂ | ∂ | ? | ∃ | ∃ | ? | ∅ | ∅ | ? | ∇ | ∇ |
∈ | ∈ | ∈ | ? | ∉ | ∉ | ? | ∋ | ∋ | ∏ | ∏ | ∏ | ∑ | ∑ | ∑ |
? | − | − | ? | ∗ | ∗ | √ | √ | √ | ∝ | ∝ | ∝ | ∞ | ∞ | ∞ |
∠ | ∠ | ∠ | ∧ | ∧ | ∧ | ∨ | ∨ | ∨ | ∩ | ∩ | ∩ | ∪ | ∪ | ∪ |
∫ | ∫ | ∫ | ∴ | ∴ | ∴ | ~ | ∼ | ∼ | ∝ | ≅ | ≅ | ≈ | ≈ | ≈ |
≠ | ≠ | ≠ | ≡ | ≡ | ≡ | ≤ | ≤ | ≤ | ≥ | ≥ | ≥ | ? | ⊂ | ⊂ |
? | ⊃ | ⊃ | ? | ⊄ | ⊄ | ? | ⊆ | ⊆ | ? | ⊇ | ⊇ | ⊕ | ⊕ | ⊕ |
? | ⊗ | ⊗ | ⊥ | ⊥ | ⊥ | ? | ⋅ | ⋅ | ? | ⌈ | ⌈ | ? | ⌉ | ⌉ |
? | ⌊ | ⌊ | ? | ⌋ | ⌋ | ? | ⟨ | 〈 | ? | ⟩ | 〉 | ? | ◊ | ◊ |
? | ♠ | ♠ | ? | ♣ | ♣ | ? | ♥ | ♥ | ? | ♦ | ♦ |
显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 | 显示 | 名称 | 编号 |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
" | " | " | & | & | & | < | < | < | > | > | > | ? | Œ | Œ |
? | œ | œ | ? | Š | Š | ? | š | š | ? | Ÿ | Ÿ | ? | ˆ | ˆ |
? | ˜ | ˜ | ? |   |   | ? |   |   | ? |   |   | ? | ‌ | ‌ |
? | ‍ | ‍ | ? | ‎ | ‎ | ? | ‏ | ‏ | – | – | – | — | — | — |
‘ | ‘ | ‘ | ’ | ’ | ’ | ? | ‚ | ‚ | “ | “ | “ | ” | ” | ” |
? | „ | „ | ? | † | † | ? | ‡ | ‡ | ‰ | ‰ | ‰ | ? | ‹ | ‹ |
? | › | › | € | € | € |
转义序列 | 字符 |
---|---|
\b | 退格 |
\f | 走纸换页 |
\n | 换行 |
\r | 回车 |
\t | 横向跳格 (Ctrl-I) |
\‘ | 单引号 |
\" | 双引号 |
\\ | 反斜杠 |
编程的时候要注意特殊字符的问题,很多运行时出现的问题都是因为特殊字符的出现而引起的。
注意,由于反斜杠本身用作转义符,因此不能直接在脚本中键入一个反斜杠。如果要产生一个反斜杠,必须一起键入两个反斜杠 (\\)。
(程序代码来源于网络)
Js版
<script> test = "你好abc" str = "" for( i=0; i<test.length; i++ ) { temp = test.charCodeAt(i).toString(16); str += "\\u"+ new Array(5-String(temp).length).join("0") +temp; } document.write (str) </script>
vbs版
Function Unicode(str1) Dim str,temp str = "" For i=1 to len(str1) temp = Hex(AscW(Mid(str1,i,1))) If len(temp) < 5 Then temp = right("0000" & temp, 4) str = str & "\u" & temp Next Unicode = str End Function
Function htmlentities(str) For i = 1 to Len(str) char = mid(str, i, 1) If Ascw(char) > 128 then htmlentities = htmlentities & "&#" & Ascw(char) & ";" Else htmlentities = htmlentities & char End if Next End Function
coldfusion版
function nochaoscode(str) { var new_str = “”; for(i=1; i lte len(str);i=i+1){ if(asc(mid(str,i,1)) lt 128){ new_str = new_str & mid(str,i,1); }else{ new_str = new_str & “&##” & asc(mid(str,i,1)); } } return new_str; }
附:
在php中我们可以用mbstring的mb_convert_encoding函数实现这个正向及反向的转化。 如:
mb_convert_encoding ("你好", "HTML-ENTITIES", "gb2312"); //输出:你好
mb_convert_encoding ("你好", "gb2312", "HTML-ENTITIES"); //输出:你好
如果需要对整个页面转化,则只需要在php文件的头部加上这三行代码:
mb_internal_encoding("gb2312"); // 这里的gb2312是你网站原来的编码
mb_http_output("HTML-ENTITIES");
ob_start(‘mb_output_handler‘);
以上内容 声明:转载来自:http://www.cnblogs.com/lf6112/p/4952001.html
HTML的标签的过滤,欢迎指正~~~~
1 #import <Foundation/Foundation.h> 2 3 @interface filterHTML : NSObject 4 //过滤 5 /** 6 * 过滤标签 7 */ 8 +(NSString *)filterHTML:(NSString *)str; 9 +(NSString *)filterHTMLImage:(NSString *)str; 10 /** 11 * 替换部分标签 12 */ 13 + (NSString *)filterHTMLTag:(NSString *)str; 14 15 16 @end
1 #import "filterHTML.h" 2 3 @implementation filterHTML 4 5 /** 6 * 过滤标签 7 */ 8 +(NSString *)filterHTML:(NSString *)str 9 { 10 NSScanner * scanner = [NSScanner scannerWithString:str]; 11 NSString * text = nil; 12 while([scanner isAtEnd]==NO) 13 { 14 //找到标签的起始位置 15 [scanner scanUpToString:@"<" intoString:nil]; 16 //找到标签的结束位置 17 [scanner scanUpToString:@">" intoString:&text]; 18 //替换字符 19 str = [str stringByReplacingOccurrencesOfString:[NSString stringWithFormat:@"%@>",text] withString:@""]; 20 } 21 return str; 22 } 23 +(NSString *)filterHTMLImage:(NSString *)str{ 24 NSScanner * scanner = [NSScanner scannerWithString:str]; 25 NSString * text = nil; 26 while([scanner isAtEnd]==NO) 27 { 28 //找到标签的起始位置 29 [scanner scanUpToString:@"<img" intoString:nil]; 30 //找到标签的结束位置 31 [scanner scanUpToString:@">" intoString:&text]; 32 //替换字符 33 str = [str stringByReplacingOccurrencesOfString:[NSString stringWithFormat:@"%@>",text] withString:@"【图片】"]; 34 } 35 return str; 36 } 37 38 + (NSString *)filterHTMLTag:(NSString *)str { 39 //替换字符 40 str = [str stringByReplacingOccurrencesOfString:@"—" withString:@"-"]; 41 str = [str stringByReplacingOccurrencesOfString:@"“" withString:@"\""]; 42 str = [str stringByReplacingOccurrencesOfString:@"”" withString:@"\""]; 43 str = [str stringByReplacingOccurrencesOfString:@" " withString:@" "]; 44 str = [str stringByReplacingOccurrencesOfString:@"’" withString:@"’"]; 45 str = [str stringByReplacingOccurrencesOfString:@"‘" withString:@"‘"]; 46 str = [str stringByReplacingOccurrencesOfString:@"·" withString:@"·"]; 47 str = [str stringByReplacingOccurrencesOfString:@""" withString:@"\""]; 48 str = [str stringByReplacingOccurrencesOfString:@"&" withString:@"&"]; 49 str = [str stringByReplacingOccurrencesOfString:@"<strong>" withString:@""]; 50 str = [str stringByReplacingOccurrencesOfString:@"</strong>" withString:@""]; 51 str = [str stringByReplacingOccurrencesOfString:@"\n" withString:@" "]; 52 return str; 53 54 } 55 @end
标签:with alpha 如何 ring pre ret entity lambda 过滤
原文地址:http://www.cnblogs.com/Wild-orangutans/p/6524260.html