专业编程基础技术教程

网站首页 > 基础教程 正文

java中反斜杠\的两种处理方法对比

ccvgpt 2024-07-21 17:42:54 基础教程 13 ℃

引用场景:

问题1:从一个表中查询出数据,然后插入另外一个表。表中某字段attr_value的值含有 反斜杠,例如:name:=ct00\$cphBaseCond\$cmd,name2:=ct00\$cphBaseCond\$cmd

java中反斜杠\的两种处理方法对比

分析:

  1. 查询出来的数据存储到java的String变量,\不会自动转义为\\,因此需要手动转义
  2. 转义的方法可以用replace和replaceAll两种方法,这里需要注意两种方法对转义字符的差异。
  3. replaceAll会对输入的字符串增加一次转义,用于处理正则表达式的转换。

实现方法对比如下:

package cn.ltdi;

public class TranslateSQLCharacter {
 // 使用replaceAll 替换 反斜杠
 public String TranslateString2SQLbyreplaceAll(String exeSQL)
 {
 //在参数专递过程进行了一次转义,在正则表达式的处理过程又进行了一次转义
 String objectAttr_new = exeSQL.replaceAll("\\\\","\\\\\\\\");
 return objectAttr_new;
 }

 // 使用replace 替换 反斜杠
 public String TranslateString2SQLbyreplace(String exeSQL)
 {

 String objectAttr_new = exeSQL.replace("\\","\\\\");
 return objectAttr_new;
 }

 public static void main(String []args){
 TranslateSQLCharacter tsc = new TranslateSQLCharacter();
 String objectAttr = "name:=ct00\\$cphBaseCond\\$cmd,name2:=ct00\\$cphBaseCond\\$cmd";
 System.out.println(objectAttr);
 String objectAttrNew = tsc.TranslateString2SQLbyreplaceAll(objectAttr);
 System.out.println(objectAttrNew);
 objectAttrNew = tsc.TranslateString2SQLbyreplace(objectAttr);
 System.out.println(objectAttrNew);
 }
}

执行结果:

name:=ct00\$cphBaseCond\$cmd,name2:=ct00\$cphBaseCond\$cmd

name:=ct00\\$cphBaseCond\\$cmd,name2:=ct00\\$cphBaseCond\\$cmd

name:=ct00\\$cphBaseCond\\$cmd,name2:=ct00\\$cphBaseCond\\$cmd

Process finished with exit code 0

Tags:

最近发表
标签列表