struts json序列化遇上replaceAll就出问题

本文介绍了一个使用Struts JSON插件进行序列化时遇到的问题:特殊字符被错误地处理导致JSON字符串不合法。通过调整replaceAll方法的使用方式解决了此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

是用struts 的json插件进行序列化

 代码如下:

@Test
	public void test_json() throws JSONException {
		Map<String, String> map = new HashMap<String, String>();
		map.put("name", "whua\"ng");
		String result = JSONUtil.serialize(map);

		System.out.println(result);
		String source = "{\"result\":\"_jsonPlaceHolder\"}";
		String result2=source.replaceAll("\"" + "_jsonPlaceHolder" + "\"", result);
		System.out.println(result2);
	}

 运行结果如下:

{"name":"whua\"ng"}

{"result":{"name":"whua"ng"}}

 

是用json解析时报错,{"result":{"name":"whua"ng"}} 不是合法的json字符串。

经过反复看,发现whua\"ng中的斜杠没有了!!!!

问题出在replaceAll

 

解决方法如下

(添加).replaceAll("\\\\", "\\\\\\\\")

@Test
	public void test_json() throws JSONException {
		Map<String, String> map = new HashMap<String, String>();
		map.put("name", "whua\"ng");
		String result = JSONUtil.serialize(map);

		System.out.println(result);
		String source = "{\"result\":\"_jsonPlaceHolder\"}";
		String result2 = source.replaceAll("\"" + "_jsonPlaceHolder" + "\"",
				result.replaceAll("\\\\", "\\\\\\\\"));
		System.out.println(result2);
	}

 

 

### Java Gson 反序列化处理字母大小写敏感性的解决方案 当使用Gson进行反序列化操作时,默认情况下,属性名称匹配是区分大小写的。这意味着JSON中的键名必须严格与Java类字段名相匹配才能成功映射数据。然而,在实际开发过程中可能会遇到不同端之间传递的数据存在命名风格差异的情况,比如前端JavaScript发送过来的请求参数可能是驼峰式(camelCase),而后端期望的是下划线形式(snake_case)。为了应对这种情况并提高灵活性,可以采取如下措施来解决大小写敏感问题: #### 方法一:自定义FieldNamingStrategy 通过创建一个继承`FieldNamingStrategy`接口的新类,并重写其中的方法来自定义字段名称转换逻辑。 ```java public class CustomFieldNamingPolicy extends FieldNamingPolicy { @Override protected String translateName(Field f) { // 实现将json key转成小写下划线的形式或其他任何规则 return convertToSnakeCase(f.getName()); } private static final Pattern UPPER_CASE_PATTERN = Pattern.compile("[A-Z]"); public static String convertToSnakeCase(String name){ Matcher matcher = UPPER_CASE_PATTERN.matcher(name); StringBuffer sb = new StringBuffer(); while (matcher.find()){ matcher.appendReplacement(sb, "_"+matcher.group(0).toLowerCase()); } matcher.appendTail(sb); return sb.toString().replaceAll("^_", ""); } } ``` 接着配置Gson实例以应用这个策略: ```java Gson gson = new GsonBuilder() .setFieldNamingPolicy(new CustomFieldNamingPolicy()) .create(); // 使用此gson对象来进行反序列化工作即可自动适配大小写不同的情况 MyClass obj = gson.fromJson(jsonString, MyClass.class)[^1]; ``` 这种方法适用于整个项目统一采用某种特定的命名约定场景;但如果只是针对个别字段有特殊需求,则推荐第二种方法。 #### 方法二:利用@SerializedName注解指定别名 对于单个成员变量来说,最简单的方式就是在其上方添加`@SerializedName`注解,并给对应的JSON Key值作为参数传入。这种方式不仅能够很好地兼容大小写字母不一致的问题,而且还可以用来表示同一个实体类的不同版本API返回结构变化等问题。 ```java class Person{ @SerializedName("first_name") private String firstName; @SerializedName("last_Name") private String lastName; // getter setter... } // 创建默认的Gson实例就可以正常解析了 Gson gson = new Gson(); Person person = gson.fromJson("{\"first_name\":\"John\", \"last_Name\": \"Doe\"}", Person.class)[^2]; ``` 这两种方法都可以有效地帮助开发者克服由于大小写引起的反序列化难题。选择哪种取决于具体的应用场景和个人偏好。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值