前端向后端传递JSON数据出现乱码问题的解决办法

前端向后端传递JSON数据出现乱码问题解决的解决办法

前提

  • Tomcat(默认编码为iso-8859-1)
  • 已添加编码过滤器(utf-8)

问题描述

前端向后端返回JSON,后端得到的JSON字符串中,中文出现乱码

{
     "id":-1,"name":"杩欐槸涓枃瀛楃","deadline":"2020-05-28T12:01:48.222Z","uid":-1,"finish":false}

前端AJAX

$.ajax({
     
		type : "post",
		url : url,
		data : json,
		contentType : "application/json;charset=utf-8",
		dataType : "text",
		success : function(msg) {
     
			// ...
		}
});

后端解析JSON字符串所用到的方法如下

	public String getJson(HttpServletRequest req, HttpServletResponse resp) throws IOException {
     
		// 获取JSON数据
		ServletInputStream is = req.getInputStream();
		byte[] buffer = new byte[1024];
		StringBuilder sb = new StringBuilder();
		while (is.read(buffer) != -1) {
     
			// 造成中文乱码的原因
			sb.append(new String(buffer));
		}
		String json = sb.toString().trim();
		System.out.println(json);
		// 调试用
		return json;
	}

造成中文乱码的原因是,Tomcat默认的编码是iso-8859-1,在上面的代码中,编码过滤器不知为何没有起到效果,后端按iso-8859-1对数据进行解码,最后得到的字符串自然是乱码了。

所以,为了避免中文乱码,需要手动地指明以utf-8形式对数据进行解码。

	public String getJson(HttpServletRequest req, HttpServletResponse resp) throws IOException {
     
		// 获取JSON数据
		ServletInputStream is = req.getInputStream();
		byte[] buffer = new byte[1024];
		StringBuilder sb = new StringBuilder();
		while (is.read(buffer) != -1) {
     
			// tomcat按默认的编码: iso-8859-1对其进行解码
			// 所以在这里需要手动地指明用utf-8来解码
			sb.append(new String(buffer, "utf-8"));
		}
		String json = sb.toString().trim();
		System.out.println(json);
		// 调试用
		return json;
	}

你可能感兴趣的:(前端)