Struts2返回的Json的文本格式带转义过的双引号和反斜杠

问题描述见:http://www.iteye.com/problems/87448

Struts2里面的Action对象的result的String Print出来的结果没有问题
{"id":"4028efd439422d260139422d2a530000","name":"department"}

在Struts.xml里面配置的
<package name="jsons" namespace="/" extends="json-default">
<action name="jsoninfo" class="personAction">
<result name="department" type="json">
<param name="root">result</param>  
</result>
</action>
</package>

然后再浏览器中输入对应的地址调用
返回的结果是:
"{\"id\":\"4028efd439422d260139422d2a530000\",\"name\":\"department\"}"

说明返回成果,但是文本的格式我用Jquery 的json完全不能解析这样子格式的对象,如果当做string类型来拆分过滤掉引号和反斜杠岂不有些多此一举,我只能想象可能是我哪里没有设置什么,请大家过目。

在$.ajax中返回的的是正在的JSON格式的对象,我认为是在最后的输出过程中做了一次我不想要的转义,求解。
例如:
JSONUtil.serialize(obj.toString());


我只想在浏览器中得到这样子的结果
{"id":"4028efd439422d260139422d2a530000","name":"department"}


问题补充:eval这种客户端转化的过程是我非常不想用的功能函数,浏览器的兼容性和性能也不是非常好,所以我还是期望能直接调用jquery的函数直接能得到正规的JSON格式的文件,不管是$.ajax 还是$.getJSON都能拿到JSON而不是无法辨认的对象。当然不通过eval方式。说白了就是在服务器端解决这个问题,还得用Struts。

解决方法:被注释掉的是会出现:Struts2返回的Json的文本格式带转义过的双引号和反斜杠问题的方法:解决方法如下:

//	public String inBoxTest() throws JSONException {
//		HttpServletRequest resp = ServletActionContext.getRequest();  
//	    HttpServletResponse response = ServletActionContext.getResponse();  
//	    response.setCharacterEncoding("UTF-8");  
//	    PrintWriter out = response.getWriter();  
//		String hql = "From Letter letter order by sendTime desc";
//		letterPage = letterService.queryByPage(hql, 12, pager.getOffset());
//		List<Letter> list=letterPage.getRows();
//		JSONArray  jsonObject = JSONArray .fromObject(list);
//		System.out.println(jsonObject);
//		rows=jsonObject.toString();
//		System.out.println(rows);
//		total=letterPage.getTotal();
//		return "test";
//	}
	public String inBoxTest() {  
	       try {  
	           HttpServletRequest re = ServletActionContext.getRequest();  
	           HttpServletResponse response = ServletActionContext.getResponse();  
	           response.setCharacterEncoding("UTF-8");  
	           PrintWriter out = response.getWriter();  
		   	   String hql = "From Letter letter order by sendTime desc";
		   	   letterPage = letterService.queryByPage(hql, 12, pager.getOffset());
		   	   List<Letter> list=letterPage.getRows();
		       total=letterPage.getTotal();
		   	   Map<String, Object> json = new HashMap<String, Object>(); 
	           json.put("total", total);// total键 存放总记录数,必须的  
	           json.put("rows", list);// rows键 存放每页记录 list  
	           JSONObject  jsonObject = JSONObject.fromObject(json);// 格式化result一定要是JSONObject  
	           out.print(jsonObject);  
	           out.flush();  
	           out.close();  
	       } catch (IOException e) {  
	           System.out.println(e);  
	       }  
	       return null;  
	    } 



posted on 2013-12-19 21:34  天神Deity  阅读(916)  评论(0编辑  收藏  举报

导航