JSON
Json基本介绍
JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别广泛。
语法
在 JavaScript 语言中,一切都是对象。因此,任何JavaScript 支持的类型都可以通过 JSON 来表示,例如字符串、数字、对象、数组等。看看他的要求和语法格式:
- 对象表示为键值对,数据由逗号分隔
- 花括号保存对象
- 方括号保存数组
JSON 键值对是用来保存 JavaScript 对象的一种方式,和 JavaScript 对象的写法也大同小异,键/值对组合中的键名写在前面并用双引号 “” 包裹,使用冒号 : 分隔,然后紧接着值:
1 2 3
| {"name": "QinJiang"} {"age": "3"} {"sex": "男"}
|
JSON 是 JavaScript 对象的字符串表示法,它使用文本表示一个 JS 对象的信息,本质是一个字符串。
1 2
| var obj = {a: 'Hello', b: 'World'}; var json = '{"a": "Hello", "b": "World"}';
|
Jackson工具类
需求
使用@ResponseBody
注解实现将controller方法返回对象转换为json
响应给客户端。
基本使用
step1: 需要用到第三方的工具jar包jackson
, 可以取Maven官网去找到坐标 https://mvnrepository.com/
1 2 3 4 5
| <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.10.1</version> </dependency>
|
step2: User实体类
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
| package com.uestc.pojo; public class User { private String name; private String sex; Integer age;
public User(){
} public User(String name, String sex, Integer age){ this.name=name; this.sex=sex; this.age=age; }
public String getName() { return name; }
public void setName(String name) { this.name = name; }
public String getSex() { return sex; }
public void setSex(String sex) { this.sex = sex; }
public Integer getAge() { return age; }
public void setAge(Integer age) { this.age = age; } @Override public String toString() { return "User{" + "name='" + name + '\'' + ", sex='" + sex + '\'' + ", age=" + age + '}'; } }
|
step3: 控制器代码
1 2 3 4 5 6 7 8 9 10 11 12 13
| @Controller @RequestMapping("/json") public class TestJson { @RequestMapping(value = "/json1") @ResponseBody public String json1() throws JsonProcessingException{ User user=new User("lfTech","男",18); ObjectMapper mapper=new ObjectMapper();
String str=mapper.writeValueAsString(user); return str; } }
|
step4: 启动tomcat服务器
中文乱码问题:
出现了中文乱码问题,可以通过@RequestMapping
的produces
属性来解决
1 2 3 4 5 6 7 8 9 10 11 12 13
| @Controller @RequestMapping("/json") public class TestJson { @RequestMapping(value = "/json1",produces = "application/json;charset=utf-8") @ResponseBody public String json1() throws JsonProcessingException{ User user=new User("lfTech","男",18); ObjectMapper mapper=new ObjectMapper();
String str=mapper.writeValueAsString(user); return str; } }
|
然后重启tomcat服务器,乱码问题解决!
继续优化:
如果项目中有很多的请求都需要添加,这样显得很麻烦。我们可以通过Spring配置统一:
在springmvc的配置文件上添加StringHttpMessageConverter
转换配置。
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| <mvc:annotation-driven> <mvc:message-converters register-defaults="true"> <bean class="org.springframework.http.converter.StringHttpMessageConverter"> <constructor-arg value="UTF-8"></constructor-arg> </bean> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <property name="objectMapper"> <bean class="org.springframework.http.converter.json.Jackson2ObjectMapperFactoryBean"> <property name="failOnEmptyBeans" value="false"></property> </bean> </property> </bean> </mvc:message-converters> </mvc:annotation-driven>
|
返回json字符串统一解决
在类上直接使用 @RestController
,这样子,里面所有的方法都只会返回 json 字符串了,不用再每一个都添加@ResponseBody
!我们在前后端分离开发中,一般都使用 @RestController
,十分便捷!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| @Controller @RequestMapping("/json") @RestController public class TestJson { @RequestMapping(value = "/json1") public String json1() throws JsonProcessingException{ User user=new User("lfTech","男",18); ObjectMapper mapper=new ObjectMapper(); String str=mapper.writeValueAsString(user); return str; } }
|
测试list集合
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
| @Controller @RequestMapping("/json") @RestController public class TestJson { @RequestMapping(value = "/json1") public String json1() throws JsonProcessingException{ User user1=new User("lfTech1","男",18); User user2=new User("lfTech2","男",19); User user3=new User("lfTech3","男",20); User user4=new User("lfTech4","男",21); List<User> list=new ArrayList<User>(); list.add(user1); list.add(user2); list.add(user3); list.add(user4); ObjectMapper mapper=new ObjectMapper(); String str=mapper.writeValueAsString(list); return str; } }
|
启动tomcat服务器:
输出时间对象
1 2 3 4 5 6 7 8 9 10 11 12
| @Controller @RequestMapping("/json") @RestController public class TestJson { @RequestMapping(value = "/json2") public String json2() throws JsonProcessingException{ Date date=new Date(); ObjectMapper mapper=new ObjectMapper(); String str=mapper.writeValueAsString(date); return str; } }
|
运行结果:
会发现日期变成了时间戳!
- 默认日期格式会变成一个数字,是1970年1月1日到当前日期的毫秒数!
- Jackson 默认是会把时间转成
timestamps
形式
解决方案:取消timestamps形式,自定义时间格式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| @Controller @RequestMapping("/json") @RestController public class TestJson { @RequestMapping(value = "/json2") public String json2() throws JsonProcessingException{ Date date=new Date(); ObjectMapper mapper=new ObjectMapper(); mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS,false); SimpleDateFormat sf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); mapper.setDateFormat(sf); String str=mapper.writeValueAsString(date); return str; } }
|
结果展示:
抽象为工具类
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| public class JsonUtils { public static String getJson(Date date){ return JsonUtils.getJson(date,"YYYY-MM-dd HH:mm:ss"); } public static String getJson(Date date, String datePattern){ ObjectMapper mapper=new ObjectMapper(); mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS,false); SimpleDateFormat sf=new SimpleDateFormat(datePattern); mapper.setDateFormat(sf);
String str= null; try { str = mapper.writeValueAsString(date); } catch (JsonProcessingException e) { e.printStackTrace(); } return str; }
|
使用工具类:
1 2 3 4 5 6
| public class TestJson { @RequestMapping(value = "/json2") public String json2(){ return JsonUtils.getJson(new Date()); } }
|
FastJson工具类
fastjson.jar
是阿里开发的一款专门用于Java开发的包,可以方便的实现json对象
与JavaBean对象
的转换,实现JavaBean对象与json字符串的转换,实现json对象与json字符串的转换。实现json的转换方法很多,最后的实现结果都是一样的。
step1: 添加fastjson
的依赖
1 2 3 4 5
| <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.62</version> </dependency>
|
step2:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
| public class TestFastJson { public static void main(String[] args) { User user1=new User("lfTech1","男",18); User user2=new User("lfTech2","男",19); User user3=new User("lfTech3","男",20); User user4=new User("lfTech4","男",21); List<User> list=new ArrayList<User>(); list.add(user1); list.add(user2); list.add(user3); list.add(user4); System.out.println("*******Java对象 转 JSON字符串*******"); String str1 = JSON.toJSONString(list); System.out.println("JSON.toJSONString(list)==>"+str1); String str2 = JSON.toJSONString(user1); System.out.println("JSON.toJSONString(user1)==>"+str2);
System.out.println("\n****** JSON字符串 转 Java对象*******"); User jp_user1=JSON.parseObject(str2,User.class); System.out.println("JSON.parseObject(str2,User.class)==>"+jp_user1);
System.out.println("\n****** Java对象 转 JSON对象 ******"); JSONObject jsonObject1 = (JSONObject) JSON.toJSON(user2); System.out.println("(JSONObject) JSON.toJSON(user2)==>"+jsonObject1.getString("name"));
System.out.println("\n****** JSON对象 转 Java对象 ******"); User to_java_user = JSON.toJavaObject(jsonObject1, User.class); System.out.println("JSON.toJavaObject(jsonObject1, User.class)==>"+to_java_user); }
|
step3: 结果如下