日期:2014-05-16  浏览次数:20391 次

永远不要自己拼装json

今天项目出现一个非常怪的现象,使用spring拦截的异常有时候显示不出来的问题,现在将原因和解决方案记录下,spring的拦截代码如下:

if(accept.indexOf("application/json")>-1){
			return super.getModelAndView("errors/ajax/500", ex, request);
		}


500页面的代码如下:

<%@ page language="java" contentType="application/json; charset=UTF-8" pageEncoding="UTF-8"%><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>{"errorCode":-1,"errorMsg":"${exception.message}"}


返回的错误信息如下:

{"errorCode":"-1","errorMsg":"错误代码:-20002
错误信息:ORA-20002: 3103: 项目 CUXECSWF/10888CUXECSWF120518150833 的属性 WF_NOTE 不存在。"}


放眼望去好像没有什么问题,然后就是不调用ajax的回调函数,最后没有办法,在后端生成了下json,然后打印出来,发现了问题,后端生成json的代码如下:

Map<String,String> errors = new HashMap<String,String>();
			errors.put("errorCode", "-1");
			errors.put("errorMsg", ex.getMessage());
			log.info(JSONObject.fromObject(errors).toString())


然后用这个生成的json是下面的代码:

{"errorCode":"-1","errorMsg":"错误代码:-20002\r
错误信息:ORA-20002: 3103: 项目 CUXECSWF/10888CUXECSWF120518150833 的属性 WF_NOTE 不存在。"}


所以之前在前端用jsp拼装的json是有问题的,最后将代码修改了下,在后端生存json后传递到前端,代码如下:

Map<String,String> errors = new HashMap<String,String>();
			errors.put("errorCode", "-1");
			errors.put("errorMsg", ex.getMessage());
			
			request.setAttribute("errorJson", JSONObject.fromObject(errors).toString());
			return super.getModelAndView("errors/ajax/500", ex, request);

<%@ page language="java" contentType="application/json; charset=UTF-8" pageEncoding="UTF-8"%><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>${errorJson}


这样就解决了这个问题,随着json的越来越普遍,虽然格式很简单,但是自己拼装的在不经意间就有问题。