json是什么,看了之后我才恍然大悟(一)

简介: 十、JSON前言1.Controller返回json数据2.上面的乱码问题

前言


前后端分离:后端提供接口,前端负责渲染后端的数据


中间建立的方式:1.传一个对象。2.约定一个格式json


json是一种轻量级的数据交换格式;是JS的对象标记



  • 采用完全独立于编程语言的文本格式来存储和表示数据;


  • 简洁和清晰的层次结构使得json成为理想的数据交换语言;


  • 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。


在js中,一切都是对象,因此任何js支持的类型都可以通过json来表示,例如字符串、数组等。


  • json键值对用来保存js对象的一种方式,和js对象的写法也差不多,键/值对组合中的键名写在前面并用双引号包裹,使用冒号:分割,然后紧接着值
{"name":"王木木"}
{"age":"18"}

json和js对象互转


  • 要实现从json子符串转换为js对象,使用json.parse()方法
let obj = JSON.parse('{"a":"Hello","b":"nihao"}');
//结果是{a:"Hello",b:"nihao"}
  • 要实现从js对象转换为json字符串,使用JSON.stringify()方法;
let json = JSON.stringify({a:"Hello",b:"nihao"});
//结果是'{"a":"Hello","b":"nihao"}'

仔细看区别,不仔细看还以为是一样的。


>💻

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script>
        //编写一个js对象
        let user={
            "name":"王木木",
            "age":"18"
        };
        //将js对象转换为json对象
        let json = JSON.stringify({a:"Hello",b:"nihao"});
        //将json对象转换为js对象
        let obj = JSON.parse('{"a":"Hello","b":"nihao"}');
        console.log(obj)
        console.log(user);
        console.log(json);
    </script>
</head>
<body>
</body>
</html>

我们发现对象是可以展开的,但是json是一个字符串

微信图片_20211230222152.png


1.Controller返回json数据


工具有Jackson和阿里巴巴的fastjson后面都会遇到。


>jackson💻

<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.13.0</version>
</dependency>


>web.xml💻


<!--1.配置DispatcherServlet-->
<servlet>
    <servlet-name>springmvc</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:springmvc-servlet.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>springmvc</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>
<!--2.配置 SpringMVC的乱码过滤-->
<filter>
    <filter-name>encoding</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>utf-8</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>encoding</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>


>springmvcservlet.xml💻

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
    <!--自动扫描包,让指定包下的注解生效,由IOC容器统一管理-->
    <context:component-scan base-package="com.hxl.controller"/>
    <!--过滤静态资源-->
    <mvc:default-servlet-handler/>
    <!--支持MVC注解驱动-->
    <mvc:annotation-driven/>
    <!--视图解析器:模板引擎 Thymeleaf Freemarker-->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
        <!--前缀,后缀-->
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <property name="suffix" value=".jsp"/>
    </bean>
</beans>

>💻

package com.hxl.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
//记得导入lombok
@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
    private String name;
    private int age;
    private String sex;
}

>controller💻

@Controller
public class UserController {
    @RequestMapping("/j1")
    @ResponseBody //他不会去走视图解析器,会直接返回一个字符串
    private String jso1(){
        //创建一个对象
        User user = new User("王木木", 18, "男");
        return user.toString();
    }
}

>artifactlibjartomcat💻


在这里我们看到了乱码,此时镇定一下不要慌。


微信图片_20211230222446.png

来看一下json的字符串格式

@Controller
public class UserController {
    @RequestMapping("/j1")
    @ResponseBody //他不会去走视图解析器,会直接返回一个字符串
    private String jso1() throws JsonProcessingException {
        //jackson,ObjectMapper
        ObjectMapper mapper = new ObjectMapper();
        //创建一个对象
        User user = new User("王木木", 18, "男");
        String str = mapper.writeValueAsString(user);
        return str;
    }
}

微信图片_20211230222529.png

2.上面的乱码问题


  • 在@Requestmapping中有一个produces属性
//produces:指定响应体返回类型和编码
@RequestMapping(value="/j1",produces = "application/json;charset=utf-8")

微信图片_20211230222555.png


  • 上述的方法比较麻烦,通过springmvc配置文件统一解决
<!--解决json 乱码配置-->
<mvc:annotation-driven>
    <mvc:message-converters register-defaults="true">
        <bean class="org.springframework.http.converter.StringHttpMessageConverter">
            <constructor-arg value="UTF-8"/>
        </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"/>
                </bean>
            </property>
        </bean>
    </mvc:message-converters>
</mvc:annotation-driven>
  • 如果在类上标注了@RestController,那么下面的方法只会返回json字符串


微信图片_20211230222645.png

  • @Controller是会走视图解析器


  • @ResponseBody //他不会去走视图解析器,会直接返回一个字符串。和@Controller配合使用,如果是@RestController,那么就不需要这个了


相关文章
|
JSON fastjson 数据格式
json是什么,看了之后我才恍然大悟(二)
3. 返回一个List集合 4. 返回一个时间 (重要) 5. FastJson
json是什么,看了之后我才恍然大悟(二)
|
存储 JSON JavaScript
JSON 是什么
JSON 是什么
175 0
|
XML JSON 前端开发
JSON是什么,为什么这么流行?
前几天分享了《Spring Boot 返回 JSON 数据,一分钟搞定!》,好些人对 JSON 还没有一个清晰的认识,今天栈长带大家来认识一下什么是JSON。
|
2月前
|
XML 存储 JSON
Twaver-HTML5基础学习(19)数据容器(2)_数据序列化_XML、Json
本文介绍了Twaver HTML5中的数据序列化,包括XML和JSON格式的序列化与反序列化方法。文章通过示例代码展示了如何将DataBox中的数据序列化为XML和JSON字符串,以及如何从这些字符串中反序列化数据,重建DataBox中的对象。此外,还提到了用户自定义属性的序列化注册方法。
45 1
|
24天前
|
数据采集 JSON 数据处理
抓取和分析JSON数据:使用Python构建数据处理管道
在大数据时代,电商网站如亚马逊、京东等成为数据采集的重要来源。本文介绍如何使用Python结合代理IP、多线程等技术,高效、隐秘地抓取并处理电商网站的JSON数据。通过爬虫代理服务,模拟真实用户行为,提升抓取效率和稳定性。示例代码展示了如何抓取亚马逊商品信息并进行解析。
抓取和分析JSON数据:使用Python构建数据处理管道
|
10天前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
14天前
|
JSON 缓存 前端开发
PHP如何高效地处理JSON数据:从编码到解码
在现代Web开发中,JSON已成为数据交换的标准格式。本文探讨了PHP如何高效处理JSON数据,包括编码和解码的过程。通过简化数据结构、使用优化选项、缓存机制及合理设置解码参数等方法,可以显著提升JSON处理的性能,确保系统快速稳定运行。
|
7天前
|
JSON API 数据安全/隐私保护
拍立淘按图搜索API接口返回数据的JSON格式示例
拍立淘按图搜索API接口允许用户通过上传图片来搜索相似的商品,该接口返回的通常是一个JSON格式的响应,其中包含了与上传图片相似的商品信息。以下是一个基于淘宝平台的拍立淘按图搜索API接口返回数据的JSON格式示例,同时提供对其关键字段的解释
|
29天前
|
JSON JavaScript Java
在Java中处理JSON数据:Jackson与Gson库比较
本文介绍了JSON数据交换格式及其在Java中的应用,重点探讨了两个强大的JSON处理库——Jackson和Gson。文章详细讲解了Jackson库的核心功能,包括数据绑定、流式API和树模型,并通过示例演示了如何使用Jackson进行JSON解析和生成。最后,作者分享了一些实用的代码片段和使用技巧,帮助读者更好地理解和应用这些工具。
在Java中处理JSON数据:Jackson与Gson库比较