利用StringEscapeUtils对字符串进行各种转义与反转义(Java)

转载自:Java我人生(陈磊兴)   原文出处:http://blog.csdn.net/chenleixing/article/details/43456987

apache工具包common-lang中有一个很有用的处理字符串的工具类,其中之一就是StringEscapeUtils,这个工具类是在2.3版本以上加上的去的,利用它能很方便的进行html,xml,java等的转义与反转义,而且还能对关键字符串进行处理预防SQL注入,不过好像common-lang3.0以后我看着好像没这个处理SQL语句的方法了,想用的话前提时引入对应的jar包,以下为它的部分方法:

它的方法,全是静态,直接用类调用即可,下边来根据代码看看它们几个的用法和效果,一看一目了然:

  1. package stringescapeutils;
  2. import org.apache.commons.lang.StringEscapeUtils;
  3. public class StringEscapeUtilsTest {
  4. public static void main(String args[]){
  5. String sql= "1' or '1'='1";
  6. System.out.println( "防SQL注入:"+StringEscapeUtils.escapeSql(sql)); //防SQL注入
  7. System.out.println( "转义HTML,注意汉字:"+StringEscapeUtils.escapeHtml( "<font>chen磊 xing</font>")); //转义HTML,注意汉字
  8. System.out.println( "反转义HTML:"+StringEscapeUtils.unescapeHtml( "<font>chen磊 xing</font>")); //反转义HTML
  9. System.out.println( "转成Unicode编码:"+StringEscapeUtils.escapeJava( "陈磊兴")); //转义成Unicode编码
  10. System.out.println( "转义XML:"+StringEscapeUtils.escapeXml( "<name>陈磊兴</name>")); //转义xml
  11. System.out.println( "反转义XML:"+StringEscapeUtils.unescapeXml( "<name>陈磊兴</name>")); //转义xml
  12. }
  13. }

输入结果:

  1. 防SQL注入: 1 '' or '' 1 ''= '' 1
  2. 转义HTML,注意汉字:<font>chen磊 xing</font>
  3. 反转义HTML:<font>chen磊 xing</font>
  4. 转成Unicode编码:\u9648\u78CA\u5174
  5. 转义XML:<name>陈磊兴</name>
  6. 反转义XML:<name>陈磊兴</name>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值