`
zoutuo1986
  • 浏览: 179664 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

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

 
阅读更多

Java我人生(陈磊兴)

 

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

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

 

[java] view plain copy
 
  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. }  

 

 

 

 

输入结果:

 

[java] view plain copy
 
  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>  



 

 

 

 

转载请注明—作者:Java我人生(陈磊兴)   原文出处:http://blog.csdn.net/chenleixing/article/details/43456987

分享到:
评论

相关推荐

    详解json串反转义(消除反斜杠).docx

    在处理 JSON 数据时,经常会遇到一些字符串需要进行反转义的情况,尤其是在从文件中读取 JSON 字符串并希望将其转换为 JSON 对象时。本文将详细介绍如何对 JSON 串进行反转义操作,并去除其中的反斜杠,以便能够正确...

    详解json串反转义(消除反斜杠)

    在JSON格式中,特殊字符如双引号(")需要通过反斜杠(\)进行转义,以便在字符串中正确地表示它们。然而,当JSON数据以字符串的形式存储或读取时(例如从文件中读取),这些反斜杠可能需要被去除,以便能够使用`...

    Java中转义字符反斜杠\的代替方法及repalceAll内涵解析

    Java中转义字符反斜杠的代替方法及repalceAll内涵解析 ...Java中转义字符反斜杠的代替方法需要根据不同的情况选择合适的方法,例如使用StringEscapeUtils工具类或replaceAll方法,以便正确地处理字符串转义问题。

    消除斜杠commons-lang3-3.12.0工具类.zip

    总结来说,Apache Commons Lang库的`StringEscapeUtils`工具类是Java开发者处理字符串转义和反转义问题的强大助手。特别是在与JSON数据打交道时,`unescapeJson()`方法可以帮助我们有效地去除反斜杠,恢复原始数据,...

    常用字符串操作的实现方式

    七、字符串转义 1、 转义特殊字符:String escaped = StringEscapeUtils.escapeJava("Hello\nWorld"); 输出结果:"Hello\\nWorld" 2、 反转义:String unescaped = StringEscapeUtils.unescapeJava(escaped); 输出...

    字符串的encode/escape

    字符串`escape`通常指的是对特殊字符进行转义,使其能够在特定上下文中正确解析。在编程语言中,例如JavaScript、Python或Java,有一些字符具有特殊含义,如`"`, `\`, `\n`, `\r`等。为了避免这些字符被解释为特殊...

    处理SQL语句commons-lang-2.6.jar

    lang中有一个很有用的处理字符串的工具类,其中之一就是StringEscapeUtils,这个工具类是在2.3版本以上加上的去的,利用它能很方便的进行html,xml,java等的转义与反转义,而且还能对关键字符串进行处理预防SQL注入,...

    java调用shell向DataX传递参数,where条件,包含特殊字符

    总之,Java调用shell脚本向DataX传递参数,尤其是在where条件中包含特殊字符时,需要关注字符串转义、shell命令构建以及安全问题。同时,合理设计和使用配置文件能有效提高代码的灵活性和可维护性。

    commons-lang3-3.4jar.rar

    总之,Apache Commons Lang 3.4库,特别是`StringEscapeUtils`类,是Java开发者处理字符串转义问题的强大工具。通过合理利用这些工具,开发者可以编写出更安全、更健壮的代码,提高应用的稳定性和安全性。

    在Java中轻松将HTML格式文本转换为纯文本(保留换行)

    第一步:引入Jsoup和lang和lang3的依赖: ...lang和lang3这两个包里有转换所需的工具类 ...import org.apache.commons.lang.StringEscapeUtils; import org.apache.commons.lang3.StringUtils; import org.jsoup.Jsoup; im

    java 常用辅助工具类

    - `StringEscapeUtils`:同样来自Apache Commons Lang,主要用于转义和unescape字符串,常用于HTML、XML和Java字符串的处理。 - `StringBuilder`与`StringBuffer`:线程安全和非线程安全的字符串操作类,适合在...

    commons-lang3-3.1.jar.zip-java Html解码组件库

    Apache Commons Lang 包含了一个名为`StringEscapeUtils`的类,它是处理字符串转义的关键。在这个3.1版本中,`StringEscapeUtils`提供了一个`unescapeHtml()`方法,可以将HTML编码的字符串解码为原始的非转义格式。...

    commons-lang3-3.8.1.rar

    总之,Apache Commons Lang 3.8.1版本的`StringEscapeUtils`类是Java开发者处理字符串转义,尤其是防止XSS攻击的一个强大工具。通过正确使用这个类,可以提高应用程序的安全性,避免恶意用户的攻击。

    domino xpages 显示双引号

    但如果你的字符串内容中包含与包围它的引号相同的类型,就需要使用转义字符`\`。比如,`var str = "He said, \"Hello!\"";` 这里,反斜杠`\`告诉JavaScript解析器,接下来的双引号不是字符串的结束,而是字符串的一...

    java防止xss注入

    1. **Apache Commons Lang**:提供`StringEscapeUtils`类,可以方便地进行字符串转义。 2. **Spring MVC**:自动对视图模型中的数据进行转义,但需开启`web.servlet.view.EscapeHtml`属性或使用`@ResponseBody`注解...

    JAVA后台使用JSON用到的JAR

    虽然不是专门处理JSON的库,但Apache Commons Lang提供了许多有用的工具类,如`StringEscapeUtils`可以用于转义JSON字符串中的特殊字符,这对于JSON格式的处理也很有帮助。 6. **JSON-P (JSR 353) 和 JSON-B (JSR ...

    JakartaCommons 详细教程更助于你的基础

    - StringEscapeUtils:字符串转义和反转义的方法。 - SystemUtils:提供获取系统属性的方法。 - Validate:数据验证工具类,提供非空验证、类型验证等。 - WordUtils:用于对字符串中的单词进行操作,如大小写转换。...

    commons-lang3-3.1_jar

    3. **JavaScript转义**:`StringEscapeUtils.escapeJavaScript(String input)`方法转义JavaScript中的特殊字符,如将 `\` 转义为 `\\`,确保字符串在JavaScript环境中安全使用。 4. **SQL转义**:虽然Apache ...

    java 工具类代码集合

    - `StringEscapeUtils`:用于转义和unescape字符串,如HTML、XML或Java字符串。 2. **数组工具类**: - `Arrays`:Java内置的工具类,提供排序、复制、填充、比较数组等功能。 - `ArrayUtils`:Apache Commons ...

    java防sql注入攻击过滤器

    例如,如果一个登录接口的用户名字段未进行有效验证,攻击者可以输入"admin' OR '1'='1 --"这样的字符串,可能导致所有用户的账户信息被显示出来。 为了解决这个问题,Java中的防SQL注入过滤器可以在数据进入数据库...

Global site tag (gtag.js) - Google Analytics