利用StringEscapeUtils对字符串进行各种转义与反转义(Java)
2015-06-04 11:28
302 查看
apache工具包common-lang中有一个很有用的处理字符串的工具类,其中之一就是StringEscapeUtils,这个工具类是在2.3版本以上加上的去的,利用它能很方便的进行html,xml,java等的转义与反转义,而且还能对关键字符串进行处理预防SQL注入,不过好像common-lang3.0以后我看着好像没这个处理SQL语句的方法了,想用的话前提时引入对应的jar包,以下为它的部分方法:
它的方法,全是静态,直接用类调用即可,下边来根据代码看看它们几个的用法和效果,一看一目了然:
package stringescapeutils;
import org.apache.commons.lang.StringEscapeUtils;
public class StringEscapeUtilsTest {
public static void main(String args[]){
String sql="1' or '1'='1";
System.out.println("防SQL注入:"+StringEscapeUtils.escapeSql(sql)); //防SQL注入
System.out.println("转义HTML,注意汉字:"+StringEscapeUtils.escapeHtml("<font>chen磊 xing</font>")); //转义HTML,注意汉字
System.out.println("反转义HTML:"+StringEscapeUtils.unescapeHtml("<font>chen磊 xing</font>")); //反转义HTML
System.out.println("转成Unicode编码:"+StringEscapeUtils.escapeJava("陈磊兴")); //转义成Unicode编码
System.out.println("转义XML:"+StringEscapeUtils.escapeXml("<name>陈磊兴</name>")); //转义xml
System.out.println("反转义XML:"+StringEscapeUtils.unescapeXml("<name>陈磊兴</name>")); //转义xml
}
}
输出结果:
防SQL注入:1'' or ''1''=''1
转义HTML,注意汉字:<font>chen磊 xing</font>
反转义HTML:<font>chen磊 xing</font>
转成Unicode编码:\u9648\u78CA\u5174
转义XML:<name>陈磊兴</name>
反转义XML:<name>陈磊兴</name>
来自:Java我人生(陈磊兴) 原文出处:http://blog.csdn.net/chenleixing/article/details/43456987
它的方法,全是静态,直接用类调用即可,下边来根据代码看看它们几个的用法和效果,一看一目了然:
package stringescapeutils;
import org.apache.commons.lang.StringEscapeUtils;
public class StringEscapeUtilsTest {
public static void main(String args[]){
String sql="1' or '1'='1";
System.out.println("防SQL注入:"+StringEscapeUtils.escapeSql(sql)); //防SQL注入
System.out.println("转义HTML,注意汉字:"+StringEscapeUtils.escapeHtml("<font>chen磊 xing</font>")); //转义HTML,注意汉字
System.out.println("反转义HTML:"+StringEscapeUtils.unescapeHtml("<font>chen磊 xing</font>")); //反转义HTML
System.out.println("转成Unicode编码:"+StringEscapeUtils.escapeJava("陈磊兴")); //转义成Unicode编码
System.out.println("转义XML:"+StringEscapeUtils.escapeXml("<name>陈磊兴</name>")); //转义xml
System.out.println("反转义XML:"+StringEscapeUtils.unescapeXml("<name>陈磊兴</name>")); //转义xml
}
}
输出结果:
防SQL注入:1'' or ''1''=''1
转义HTML,注意汉字:<font>chen磊 xing</font>
反转义HTML:<font>chen磊 xing</font>
转成Unicode编码:\u9648\u78CA\u5174
转义XML:<name>陈磊兴</name>
反转义XML:<name>陈磊兴</name>
来自:Java我人生(陈磊兴) 原文出处:http://blog.csdn.net/chenleixing/article/details/43456987
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树