SpringMVC学习笔记07--------JSON交互处理
什么是JSON?
-
JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别广泛。
-
采用完全独立于编程语言的文本格式来存储和表示数据。
-
简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。
-
易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。
在 JavaScript 语言中,一切都是对象。因此,任何JavaScript 支持的类型都可以通过 JSON 来表示,例如字符串、数字、对象、数组等。看看他的要求和语法格式:
-
对象表示为键值对,数据由逗号分隔
-
花括号保存对象
-
方括号保存数组
JSON 键值对是用来保存 JavaScript 对象的一种方式,和 JavaScript 对象的写法也大同小异,键/值对组合中的键名写在前面并用双引号 "" 包裹,使用冒号 : 分隔,然后紧接着值:
{"name": "QinJiang"}
{"age": "3"}
{"sex": "男"}
JSON与javascript的区别:
JSON 是 JavaScript 对象的字符串表示法,它使用文本表示一个 JS 对象的信息,本质是一个字符串。
var obj = {a: 'Hello', b: 'World'}; //这是一个对象,注意键名也是可以使用引号包裹的
var json = '{"a": "Hello", "b": "World"}'; //这是一个 JSON 字符串,本质是一个字符串
在js中二者相互转换如下:
// json字符串转换为js对象
var obj = JSON.parse('{"userName":"xdw","age":"18"}');
console.log(obj);
// js对象转换为json字符串
var json = JSON.stringify(obj);
console.log(json);
后台返回json数据
使用jackson
jsckson测试
通过maven引入jackson相关依赖:
com.fasterxml.jackson.core
jackson-databind
2.13.1
web.xml相关配置:
dispatcherServlet
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:applicationContext.xml
1
dispatcherServlet
/
encoding
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
encoding
/*
applicationContext.xml配置文件:
<?xml version="1.0" encoding="UTF-8"?>
编写控制器方法:
@RequestMapping("/t1")
@ResponseBody // 这里表示将str转成json格式返回
public String test01() throws JsonProcessingException {
// 创建一个jackson对象映射器,用来解析数据
ObjectMapper mapper = new ObjectMapper();
User user = new User(1, "测试01", 18);
// 将对象转换为json字符串并返回
return mapper.writeValueAsString(user);
}
@ResponseBody
注解作用是告诉Spring,返回的数据是JSON字符串,不要把它当作视图处理- 我们可以在类上使用
@RestController
注解,如果类上添加了该注解,表示该控制器的所有返回都是json,方法上的@ResponseBody
注解可以省略
测试:
我们发现结果出现中文乱码了,我们需要设置一下他的编码格式为utf-8,以及它返回的类型;
通过@RequestMaping的produces属性来实现,修改下代码:
@RequestMapping(value="/t1", produces = {"text/plain;charset=UTF-8"})
再次测试:
乱码问题已经解决!
在实际的开发过程中,我们其实并不需要手动的将对象转换为json输出,使用了@ResponseBody
注解之后,SpringMVC会自动的将对象转换为JSON输出至前端:
@RequestMapping("/t2")
@ResponseBody // 返回JSON
public User test02() {
User user = new User(1, "测试", 18);
return user;
}
测试:
使用该种方式,我们也避免了乱码问题!
jackson乱码问题
在上面的实验中,我们虽然解决了乱码问题,但是这样一个个加注解太麻烦,我们可以在applicationContect.xml
配置文件中,修改注解驱动如下,解决乱码问题:
除了jackson外,我们常用的json工具还有GSON与fastJson等,剩下的我们就不一一介绍了,这些工具使用起来也比较简单,使用的时候查看文档即可!