zoukankan      html  css  js  c++  java
  • 利用StringEscapeUtils对字符串进行各种转义与反转义(Java)

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

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

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

    输入结果:

    1. 防SQL注入:1'' or ''1''=''1  
    2. 转义HTML,注意汉字:<font>chen磊  xing</font>  
    3. 反转义HTML:<font>chen磊  xing</font>  
    4. 转成Unicode编码:u9648u78CAu5174  
    5. 转义XML:<name>陈磊兴</name>  
    6. 反转义XML:<name>陈磊兴</name> 
  • 相关阅读:
    k8s是什么
    jmeter性能测试的策略
    面试的灵魂拷问:你最大的缺点是什么?
    面试的灵魂拷问:你做过的最令你自豪的事情是什么?
    面试的灵魂拷问:你犯过的最大的失误是什么?
    5-django rest framework,搭建api,这是最重要的章节
    4-restfulapi的介绍,vue代码结构
    组合恒等式证明——「Zeilberger 老爷子的 T 恤上写了啥?」
    「NOI2020」 美食家 【矩阵快速幂】
    [CEOI2014] The Wall【最短路】
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13317759.html
Copyright © 2011-2022 走看看