JSON

JSON

1、Json基本介绍

JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别广泛。

语法

在 JavaScript 语言中,一切都是对象。因此,任何JavaScript 支持的类型都可以通过 JSON 来表示,例如字符串、数字、对象、数组等。看看他的要求和语法格式:

  • 对象表示为键值对,数据由逗号分隔
  • 花括号保存对象
  • 方括号保存数组

JSON 键值对是用来保存 JavaScript 对象的一种方式,和 JavaScript 对象的写法也大同小异,键/值对组合中的键名写在前面并用双引号 “” 包裹,使用冒号 : 分隔,然后紧接着值:

{"name": "QinJiang"}
{"age": "3"}
{"sex": "男"}

JSON 是 JavaScript 对象的字符串表示法,它使用文本表示一个 JS 对象的信息,本质是一个字符串。

var obj = {a: 'Hello', b: 'World'}; //这是一个对象,注意键名也是可以使用引号包裹的
var json = '{"a": "Hello", "b": "World"}'; //这是一个 JSON 字符串,本质是一个字符串

2、Jackson工具类

需求

使用@ResponseBody注解实现将controller方法返回对象转换为json响应给客户端。

基本使用

step1: 需要用到第三方的工具jar包jackson, 可以取Maven官网去找到坐标 https://mvnrepository.com/

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.10.1</version>
</dependency>

step2: User实体类

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: 控制器代码

@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服务器

中文乱码问题:

出现了中文乱码问题,可以通过@RequestMappingproduces属性来解决

@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转换配置。

<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 ,十分便捷!

@Controller
@RequestMapping("/json")
@RestController
public class TestJson {
    @RequestMapping(value = "/json1")
    public String json1() throws JsonProcessingException{
        //创建一个对象
        User user=new User("lfTech","男",18);
        //创建一个jackson的对象映射器,用来解析数据
        ObjectMapper mapper=new ObjectMapper();
        //将我们的对象解析成为json格式
        String str=mapper.writeValueAsString(user);
        return str;
    }
}

测试list集合

@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);
        //创建一个jackson的对象映射器,用来解析数据
        ObjectMapper mapper=new ObjectMapper();
        //将我们的对象解析成为json格式
        String str=mapper.writeValueAsString(list);
        return str;
    }
}

启动tomcat服务器:

输出时间对象

@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形式,自定义时间格式

@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;
    }
}

结果展示:

抽象为工具类

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;
    }

使用工具类:

public class TestJson {
    @RequestMapping(value = "/json2")
    public String json2(){
        return JsonUtils.getJson(new Date());
    }
}

3、FastJson工具类

fastjson.jar是阿里开发的一款专门用于Java开发的包,可以方便的实现json对象JavaBean对象的转换,实现JavaBean对象与json字符串的转换,实现json对象与json字符串的转换。实现json的转换方法很多,最后的实现结果都是一样的。

step1: 添加fastjson的依赖

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.62</version>
</dependency>

step2:

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: 结果如下

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值