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

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

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>chenxing</font>
    反转义HTML:<font>chenxing</font>
    转成Unicode编码:\u9648\u78CA\u5174
    转义XML<name>陈磊兴</name>
    反转义XML<name>陈磊兴</name>
发布者:songJian   点击数:4034   发布时间:2020-02-28 22:10:00   更新时间:2020-02-28 22:10:00
正在加载评论...
相关文章