JSON(JavaScript Object Notation - js对象标记)
JSON是一种轻量级的数据交换格式,目前使用特别广泛。采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。
在 JS 语言总一切皆是对象,任何 JS 支持的类型都可以通过 JSON 来表示。
语法格式:
- 对象表示为键值对
- 数据由逗号分隔
- 花括号保存对象
- 方括号保存数组
示例
{"name": "张三"}
{"age":" 19"}
{"sex":"男"}
JSON 是 JS 对象的字符串表示法,使用文本表示一个 JS 对象的信息,本质上是一个字符串。
var obj ={name:'张三',age:'19'};//这是一个JS 对象,键名也可以用引号包裹
var json ={"name":"张三","age":"19"}//这是一个JSON 字符串
JS 和 JSON 相互转换
//JSON 字符串转换 JS 对象 JSON.parse()
var obj = JSON.parse('{"name":"张三","age":"19"}')
//JS 对象转换 JSON 字符串 JSON.stringify()
var json = JSON.stringify({name:'张三',age:'19'});
服务端返回JSON字符串的方法,几个小demo
@RequestMapping("/json1")
@ResponseBody
public String json1() throws JsonProcessingException{
//创建一个json对象映射器,就是一个类
ObjectMapper mapper = new ObjectMapper();
//创建一个对象
User user = new User("张三丰",20);
//使用mapper 将对象转换json字符串
String str = mapper.writeValueAsString(user);
return str;
}
//解决乱码的一种方式
@RequestMapping(value="/json2",produces="application/json; charset=utf-8")
@ResponseBody
public String json2() throws JsonProcessingException {
User user = new User("张三丰",20);
String str = new ObjectMapper().writeValueAsString(user);
return str;
}
//返回一个列表
@RequestMapping(value="/json3",produces="application/json; charset=utf-8")
@ResponseBody
public String json6() throws JsonProcessingException {
ArrayList<User> list = new ArrayList<User>();
User user1 = new User("张三丰1",20);
User user2 = new User("张三丰2",20);
User user3 = new User("张三丰3",20);
list.add(user1);
list.add(user2);
list.add(user3);
return new ObjectMapper().writeValueAsString(list);
}
//返回时间
@RequestMapping(value="/time1",produces="application/json; charset=utf-8")
@ResponseBody
public String json3() throws JsonProcessingException {
Date date = new Date();
return new ObjectMapper().writeValueAsString(date);
}
//返回自定义格式的时间
@RequestMapping(value="/time2",produces="application/json; charset=utf-8")
@ResponseBody
public String json4() throws JsonProcessingException {
ObjectMapper mapper = new ObjectMapper();
//关闭时间戳功能
mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
//格式化时间,自定义时间格式
SimpleDateFormat slf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
//让mapper指定时间格式为slf
mapper.setDateFormat(slf);
Date date = new Date();
return mapper.writeValueAsString(date);
}
为便于使用,将时间格式转换封装成一个工具类(封装思想)
public class TimeUtil {
public static String getTime(Object object) {
return getTime(object , "yyyy/MM/dd HH:mm:ss");
}
public static String getTime(Object object, String dateformat) {
ObjectMapper mapper = new ObjectMapper();
//关闭时间戳功能
mapper.configure(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS, false);
//格式化时间,自定义时间格式
SimpleDateFormat sdf = new SimpleDateFormat(dateformat);
//让mapper指定时间格式为slf
mapper.setDateFormat(sdf);
try {
return mapper.writeValueAsString(object);
} catch (JsonProcessingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return null;
}
}
调用工具类种的方法
@RequestMapping(value="/time3",produces="application/json; charset=utf-8")
@ResponseBody
public String json5() {
return JsonTimeUtil.getTime(new Date());
}