需求:
在MongoDB做查询功能的时候,如果再前端拼接查询条件,传递到后台的查询条件是一个json字符串,mongodb查询的时候,需要对特殊字符进行转义,但是查询条件里面的key和value可能是任意值,所以不能将Json直接转换为Java对象替换里面的value。

下面通过一个json转换的包来实现这个功能,需要引入依赖:

<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>fastjson</artifactId>
	<version>1.2.45</version>
</dependency>

核心代码参考如下:

	/**
	 * 转义json字符串里面的value的特殊字符,key不用管
	 * 
	 * @param jsonStr 
	 * @return 返回替换后的字符串
	 */
	public static String replaceJsonValue(String jsonStr) {
		JSONObject obj = JSON.parseObject(jsonStr);
		replaceValue(obj);
		return obj.toJSONString();
	}

	/**
	 * 递归转义value的值,目前是将所有的value的结尾都添加一个“$”,具体实现是,根据具体的需求来。
	 * 
	 * @param obj
	 */
	private static void replaceValue(JSONObject obj) {
		Set<Entry<String, Object>> keys = obj.entrySet();
		keys.forEach(key -> {
			Object value = obj.get(key.getKey());
			if (value instanceof JSONObject) { //如果还是JSONObject,继续递归遍历
				replaceValue((JSONObject) value);
			} else if (value instanceof String) {//如果是String(这里没有处理其他类型,如int,double等),表示为具体的value值
				obj.put(key.getKey(), value+"$");
			}
		});
	}

注意:这里虽然使用了递归,但是递归的深度有限,所以问题不大。

GitHub 加速计划 / js / json
41.72 K
6.61 K
下载
适用于现代 C++ 的 JSON。
最近提交(Master分支:1 个月前 )
960b763e 4 个月前
8c391e04 6 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐