您的位置:首页 > 编程语言 > Java开发

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

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


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

[java] view
plain copy

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(
4000
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  

          

    }  

}  

输入结果:

[java] view
plain copy

防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>  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐