快速业务通道

Spring的优秀工具类盘点,第2部分: 特殊字符转义和方法入参检测工具类 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-07-04
造成其后的 <table> 代码变成无效的内容;其次,② 处 <input> 被动态数据改换为按钮类型的组件(type="button")。为了避免这一问题,我们需要事先对可能破坏 HTML 文档结构的动态数据进行转义处理。Spring 为我们提供了一个简单适用的 HTML 特殊字符转义工具类,它就是 HtmlUtils。下面,我们通过一个简单的例子了解 HtmlUtils 的具体用法:

清单 2. HtmpEscapeExample

package com.baobaotao.escape; import org.springframework.web.util.HtmlUtils; public class HtmpEscapeExample {   public static void main(String[] args) {     String specialStr = "<div id=\"testDiv\">test1;test2</div>";     String str1 = HtmlUtils.htmlEscape(specialStr); ①转换为HTML转义字符表示     System.out.println(str1);     String str2 = HtmlUtils.htmlEscapeDecimal(specialStr); ②转换为数据转义表示     System.out.println(str2);     String str3 = HtmlUtils.htmlEscapeHex(specialStr); ③转换为十六进制数据转义表示     System.out.println(str3);     ④下面对转义后字符串进行反向操作     System.out.println(HtmlUtils.htmlUnescape(str1));     System.out.println(HtmlUtils.htmlUnescape(str2));     System.out.println(HtmlUtils.htmlUnescape(str3));   } }

HTML 不但可以使用通用的转义序列表示 HTML 特殊字符,还可以使用以 # 为前缀的数字序列表示 HTML 特殊字符,它们在最终的显示效果上是一样的。HtmlUtils 提供了三个转义方法:

方法 说明
static String htmlEscape(String input) 将 HTML 特殊字符转义为 HTML 通用转义序列;
static String htmlEscapeDecimal(String input) 将 HTML 特殊字符转义为带 # 的十进制数据转义序列;
static String htmlEscapeHex(String input) 将 HTML 特殊字符转义为带 # 的十六进制数据转义序列;

此外,HtmlUtils 还提供了一个能够将经过转义内容还原的方法:htmlUnescape(String input),它可以还原以上三种转义序列的内容。运行以上代码,您将可以看到以下的输出:

str1:&lt;div id=&quot;testDiv&quot;&gt;test1;test2&lt;/div&gt; str2:&#60;div id=&#34;testDiv&#34;&#62;test1;test2&#60;/div&#62; str3:&#x3c;div id=&#x22;testDiv&#x22;&#x3e;test1;test2&#x3c;/div&#x3e; <div id="testDiv">test1;test2</div> <div id="testDiv">test1;test2</div> <div id="testDiv">test1;test2</div>

您只要使用 HtmlUtils 对代码 清单 1 的 userName 和 address 进行转义处理,最终输出的 HTML 页面就不会遭受破坏了。

Spring的优秀工具类盘点,第2部分: 特殊字符转义和方法入参检测工具类(3)

时间:2011-02-06 IBM 陈雄华

JavaScript 特殊字符转义

JavaScript 中也有一些需要特殊处理的字符,如果直接将它们嵌入 JavaScript 代码中,JavaScript 程序结构将会遭受破坏,甚至被嵌入一些恶意的程序。下面列出了需要转义的特殊 JavaScript 字符:

'' :\'' " :\" \ :\\ 走纸换页: \f 换行:\n 换栏符:\t 回车:\r 回退符:\b

我们通过一个具体例子演示动态变量是如何对 JavaScrip

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号