Spring boot的开发环境和返回JSON 数据

1.Spring boot的开发环境

1.1 jdk 的配置

使用 IDEA 进行开发,在 IDEA 中配置 jdk 的方式很简单,打开 File->Project Structure
1. 选择 SDKs
2. JDK home path 中选择本地 jdk 的安装目录
3. Name 中为 jdk 自定义名字
通过以上三步骤,即可导入本地安装的 jdk 。如果是使用 STS 或者 eclipse 可以通过两步骤添加:
1 window->preference->java->Instralled JRES 来添加本地 jdk
2 window-->preference-->java-->Compiler 选择 jre ,和 jdk 保持一致。

2. Spring Boot 工程的构建

2.1 IDEA 快速构建

IDEA 中可以通过 File->New->Project 来快速构建 Spring Boot 工程。选择 Spring Initializr ,在 Project SDK
选择刚刚导入的 jdk ,点击 Next ,到了项目的配置信息。
Group :填企业域名,一般采用域名反装的方式定义,例如使用 com.yan
Artifact :填项目名称,例如工程名 demo ,如果项目规模较大这里可能会采用模块名称
Dependencies :可以添加项目中所需要的依赖信息,根据实际情况来添加,这里只需要选择 Web 即可。

2.2 官方构建

第二种方式可以通过官方构建,步骤如下:
1 、访问 http://start.spring.io/ 或者 http://start.aliyun.com/
2 、在页面上输入相应的 Spring Boot 版本、 Group Artifact 信息以及项目依赖,然后创建项目。
3 、下载解压后,使用 IDEA 导入该 maven 工程: File->New->Model from Existing Source ,然后选择解
压后的项目文件夹即可。如果是使用 eclipse 可以通过 Import->Existing Maven Projects->Next ,然后选择解
压后的项目文件夹即可。

2.3 maven 配置

创建 Spring Boot 项目后需要进行 maven 配置。打开 File->settings ,搜索 maven ,配置一下本地的 maven
息。
Maven home directory 中选择本地 Maven 的安装路径;在 User settings file 中选择本地 Maven 的配置文件
所在路径。在配置文件中配置一下国内阿里的镜像,这样在下载 maven 依赖时,速度很快。
<mirror>
<id>nexus-aliyun</id>
<mirrorOf>*</mirrorOf>
<name>Nexus aliyun</name>
<url>http://maven.aliyun.com/nexus/content/groups/public</url>
</mirror>
如果是使用 eclipse 可以通过 window-->preference-->Maven-->User Settings 来配置,配置方式和上面一致。

2.4 编码配置

同样地新建项目后,一般都需要配置编码,这点非常重要,很多初学者都会忘记这一步,所以要养成良好的习
惯。
IDEA 中仍然是打开 File->settings ,搜索 encoding ,配置一下本地的编码信息。
如果是使用 eclipse 有两个地方需要设置一下编码:
1 window--> perferences-->General-->Workspace ,将 Text file encoding 改成 utf-8
2 window-->perferences-->General-->content types ,选中 Text ,将 Default encoding 填入 utf-8
这样编码设置完成即可启动项目工程了。
3. Spring Boot 项目工程结构
Spring Boot 项目总共有三个模块
src/main/java 路径:主要编写业务程序
src/main/resources 路径:存放静态文件和配置文件
src/test/java 路径:主要编写测试程序
默认情况下会创建一个启动类 Demo01Application ,该类上面有个 @SpringBootApplication 注解,该启动类中
有个 main 方法,
Spring Boot 启动只要运行该 main 方法即可,非常方便。另外 Spring Boot 内部集成了 tomcat
不需要人为手动去配置 tomcat ,开发者只需要关注具体的业务逻辑即可。
到此为止 Spring Boot 就启动成功了,为了比较清楚的看到效果,可以写一个 Controller 来测试。注意后续开
发中定义的包必须是主包的子包,例如主包为 com.yan ,则以后的包名称为 com.yan.biz 业务、 com.yan.dao
等。进入企业的第一件事情应该是了解公司的编程规范
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController 复合注解 @ Controller+@ResponseBody @Controller 用于声明当前类是一个控制器类,
而且通过自动组件扫描会成为受管 bean @ResponseBody 用于声明当前类方法的返回值会自动转换为 JSON
格式
@RequestMapping("/start") 针对当前类中的所有方法声明名空间。定义 @RequestMapping 时如果没有属性
名称则默认名称为 value value 实际上是 path 属性的别名,只有一个属性 value 时, value 可以省略;如果多
个属性时则 value 不能省略。如果不定义 method 请求方法时,则所有的请求方法均可匹配
public class StartController {
@RequestMapping("/springboot") 针对方法进行地址映射,这里的请求 URL 地址为 /start/springboot
不是 /springboot
public String startSpringBoot() {
return "Welcome to the world of Spring Boot!";
}
}
重新运行 main 方法启动项目,在浏览器中输入 localhost:8080/start/springboot ,如果看到 Welcome to the
world of Spring Boot! ,那么项目启动成功! Spring Boot 就是这么简单方便!端口号默认是 8080 ,如果想要
修改,可以在 application.yml 文件中使用 server.port 来人为指定端口,如 8001 端口:
server:
port: 8001
在具体的应用开发中可以使用 properties 配置文件或者 yaml 配置文件两种
一般建议开发中首选 yml 格式的文件,文件后缀可以是 yml 或者 yaml 。可以通过格式缩进的方式表达层次结
构。解析 yml 格式的文件需要依赖 snakeyaml ,这个依赖由 web-starter 依赖引入
为什么选择使用 SpringBoot2.6.13 ,不使用 SpringBoot3
是因为后期开发中需要使用 SpringCloud ali JDK1.8
4. 总结
快速学习在 IDEA 中导入 jdk 以及使用 IDEA 如何配置 maven 和编码,如何快速的创建和启动 Spring Boot
程。 IDEA Spring Boot 的支持非常友好,建议使用 IDEA 进行 Spring Boot 的开发。

3、Spring Boot 返回 Json 数据

XML 文件的解析
常见的解析工具有 DOM4j JDOM 等,为了标准化 XML 文件解析, Java 中提出了 JAXP 规范,使用的解析模
型有
1. DOM :将标记语言文档一次性加载进入内存中,在内存中形成一颗 DOM 树(服务器端常用)
* 优点:操作方便,可以对文档进行 CRUD 的所有操作
* 缺点:一次性加载进入内存形成 DOM 树,非常消耗资源
2. SAX :逐行读取,基于事件驱动(安卓终端常用)
* 优点:不消耗资源
* 缺点:只能读取,不能增删改
public class Test2 {
public static void main ( String [] args) throws Exception {
SAXParserFactory parserFactory = SAXParserFactory .newInstance();
SAXParser saxParser = parserFactory .newSAXParser();
final List < Student > studentList = new ArrayList< Student >(); 因为 SAX 解析并不缓存数据,所以
解析过程中的数据需要自行编程实现存储
saxParser .parse( "xml02/students.xml" , new DefaultHandler () {
private Student student = null ;
private int flag = 0 ;
public void startElement ( String uri, String localName, String qName, Attributes attributes)
throws SAXException {
if ( "student" .equals(qName)) {
student = new Student();
String id =attributes.getValue( "id" ); // 获取当前标签的指定名称的属性
if ( id != null && id .trim().length()> 0 )
student .setId( id );
} else if ( "name" .equals(qName))
flag = 1 ;
else if ( "age" .equals(qName))
flag = 2 ;
else if ( "sex" .equals(qName))
flag = 3 ;
}
@Override
public void characters ( char [] ch, int start, int length) throws SAXException {
String tmp = new String(ch, start, length);
if ( tmp != null && tmp .trim().length()> 0 ){
if ( flag == 1 )
student .setName( tmp .trim());
else if ( flag == 2 ){
Integer kk = Integer .parseInt( tmp .trim());
student .setAge( kk );
} else if ( flag == 3 )
student .setSex( tmp .trim());
}
}
@Override
public void endElement ( String uri, String localName, String qName) throws SAXException {
flag = 0 ;
if ( "student" .equals(qName))
studentList .add( student );
}
});
studentList .forEach( System . out ::println);
}
}
早期数据传输使用 xml 作为交互格式,例如 webservice 技术,但是由于 xml 解析比较麻烦,所以现在在项目
开发中,在接口与接口之间以及前后端之间数据的传输都使用 Json 格式,在 Spring Boot 中接口返回 Json
式的数据很简单,在 Controller 中使用 @RestController 注解即可返回 Json 格式的数据, @RestController 也是
Spring Boot 新增的一个复合注解。
源代码:其中 Target Retention Documented 是元注解
@Target({ElementType.TYPE}) 用于声明注解可以使用在什么地方, Type 表示可以使用在类上
@Retention(RetentionPolicy.RUNTIME) 用于声明注解需要保持到什么阶段, Runtime 表示注解在编译生
成的字节码中一直保持到运行时
@Documented
@Controller
@ResponseBody
public @interface RestController {
String value() default "";
}
可 以看 出 @RestController 注 解包 含 了 原来 的 @Controller @ResponseBody 注 解, 使 用 过 Spring
@Controller 注解用于声明当前类是控制器类, @ResponseBody 注解是将返回的数据结构转换为 Json 格式。
所以在默认情况下,使用了 @RestController 注解即可将返回的数据结构转换成 Json 格式, Spring Boot 中默
认使用的 Json 解析技术框架是 jackson 。点开 pom.xml 中的 spring-boot-starter-web 依赖,可以看到一个
spring-boot-starter-json 依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-json</artifactId>
<scope>compile</scope>
</dependency>
Spring Boot 中对依赖都做了很好的封装,可以看到很多 spring-boot-starter-xxx 系列的依赖,这是 Spring Boot
的特点之一,不需要人为去引入很多相关的依赖了, starter-xxx 系列直接都包含了所必要的依赖,所以再次点
进去上面这个 spring-boot-starter-json 依赖,可以看到:
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-jdk8</artifactId>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-jsr310</artifactId>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.module</groupId>
<artifactId>jackson-module-parameter-names</artifactId>
<scope>compile</scope>
</dependency>
到此为止知道了 Spring Boot 中默认使用的 json 解析框架是 jackson 。默认的 jackson 框架对常用数据类型的
Json 处理。

3.1. Spring Boot 默认对 Json 的处理

在实际项目中,常用的数据结构无非有类对象、 List 对象、 Map 对象,默认的 jackson 框架对这三个常用的数
据结构都可以转成 json 的格式。
1.1 创建 User 实体类
需要创建一个实体类 User
public class User {
private Long id;
private String username;
private String password;
/* 省略 get set 和带参构造方法 */
}
1.2 创建 Controller
然后创建一个 Controller ,分别返回 User 对象、 List<User> Map<String, Object>
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@RestController
@RequestMapping("/json")
public class JsonController {
@RequestMapping("/user")
public User getUser() {
return new User(1, " 闫峻 ", "123456");
}
@RequestMapping("/list")
public List<User> getUserList() {
List<User> userList = new ArrayList<>();
User user1 = new User(1, " 闫峻 ", "123456");
User user2 = new User(2, " 死胖子 ", "123456");
userList.add(user1);
userList.add(user2);
return userList;
}
@RequestMapping("/map")
public Map<String, Object> getMap() {
Map<String, Object> map = new HashMap<>(3);
User user = new User(1, " 闫峻 ", "123456");
map.put(" 作者信息 ", user);
map.put(" 博客地址 ", "http://blog.yan.com");
map.put("CSDN 地址 ", "http://blog.csdn.net/yanjun");
map.put(" 粉丝数量 ", 4153);
return map;
}
}
1.3 测试不同数据类型返回的 json
写好了接口,分别返回了一个 User 对象、一个 List 集合和一个 Map 集合,其中 Map 集合中的 value 存的是不
同的数据类型
在浏览器中输入: localhost:8080/json/user 返回 json
{"id":1,"username":" 闫峻 ","password":"123456"}
在浏览器中输入: localhost:8080/json/list 返回 json
[{"id":1, "username":" 闫峻 ", "password":"123456"}, {"id":2, "username":" 死胖子 ", "password":"123456"}]
在浏览器中输入: `localhost:8080/json/map 返回 json
{" 作 者 信 息 " : {"id":1, "username":" 闫 峻 ", "password":"123456"}, "CSDN 地 址 " :
"http://blog.csdn.net/yanjun", " 粉丝数量 ":4153, " 博客地址 ":"http://blog.yan.com"}
可以看出 map 中不管是什么数据类型,都可以转成相应的 json 格式,这样就非常方便。
1.4 jackson 中对 null 的处理
在实际项目中,难免会遇到一些 null 值出现,转 json 时是不希望有这些 null 出现的,比如期望所有的 null
json 时都变成 "" 这种空字符串,那怎么做呢?在 Spring Boot 中做一下配置即可,新建一个 jackson 的配置
类:
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.databind.JsonSerializer;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializerProvider;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.http.converter.json.Jackson2ObjectMapperBuilder;
import java.io.IOException;
@Configuration 用于声明当前类是一个配置类,最新的注解为 @SpringBootConfiguration
public class JacksonConfig {
@Bean 用于在配置类中,表示方法的返回值是一个受管 bean
@Primary 如果多个配置,则以当前的为主
@ConditionalOnMissingBean(ObjectMapper.class) 条件注解,表示如果受管 bean 中没有 ObjectMapper
类型的对象,则需要构建
public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
ObjectMapper objectMapper = builder.createXmlMapper(false).build();
objectMapper.getSerializerProvider().setNullValueSerializer(new JsonSerializer<Object>() {
@Override
public void serialize(Object o, JsonGenerator jsonGenerator, SerializerProvider serializerProvider)
throws IOException {
jsonGenerator.writeString(""); 针对 null 内容输出空字符串
}
});
return objectMapper;
}
}
然后修改一下上面返回 map 的接口,将几个值改成 null 测试一下:
@RequestMapping("/map")
public Map<String, Object> getMap() {
Map<String, Object> map = new HashMap<>(3);
User user = new User(1, " 闫峻 ", null);
map.put(" 作者信息 ", user);
map.put(" 博客地址 ", "http://blog.yan.com");
map.put("CSDN 地址 ", null);
map.put(" 粉丝数量 ", 4153);
return map;
}
重启项目再次输入 localhost:8080/json/map ,可以看到 jackson 已经将所有 null 字段转成了空字符串了。例如
返回数据为 {" 作者信息 ":{"id":1,"username":" 闫峻 ","password":""},"CSDN 地址 ":""," 粉丝数量 ":4153," 博客地
":"http://blog.yan.com"}
配置属性不参与映射输出
@JsonIgnore 指定该属性不参与 JSON 字符串的映射
private String password ;
配置日期类型数据的映射格式
@JsonFormat (pattern = "yyyy-MM-dd" )
private Date birth = new Date();

3.2. 整合通用 Mapper 的开发方法

通用 mapper 就是基于 mybatis 的一款 MyBatis 增强插件,可以提供一些常用增、删、改、查的操作,不需要
重复写一些常用的 sql 。简化操作,精简代码,并且达到代码风格统一的目的。它的出现不是为了替代 mybatis
而是让 mybatis 的开发更方便。
添加依赖:
< dependency >
< groupId >tk.mybatis</ groupId >
< artifactId >mapper-spring-boot-starter</ artifactId >
< version >4.2.2</ version >
</ dependency >
使用通用 mapper 的开发方式,采用注解定义映射关系,自动生成常见的 SQL 语句,不需要 xml 映射元文件
/*
1. 表名默认使用类名 , 驼峰转下划线 ( 只对大写字母进行处理 ), TestUser 默认对应的表名为 test_user
2. 表名可以使用 @Table(name = "tableName") 进行指定 , 对不符合第一条默认规则的可以通过这种方式指定表
.
3. 字段默认和 @Column 一样 , 都会作为表字段 , 表字段默认为 Java 对象的 Field 名字驼峰转下划线形式 .
4. 可以使用 @Column(name = "fieldName") 指定不符合第 3 条规则的字段名
5. 使用 @Transient 注解可以忽略字段 , 添加该注解的字段不会作为表字段使用 .
6. 建议一定是有一个 @Id 注解作为主键的字段 , 可以有多个 @Id 注解的字段作为联合主键 .
7. 默认情况下 , 实体类中如果不存在包含 @Id 注解的字段 , 所有的字段都会作为主键字段进行使用 ( 这种效率极
).
8. 实体类可以继承使用 , 可以参考测试代码中的 tk.mybatis.mapper.model.UserLogin2 .
9. 由于基本类型 , int 作为实体类字段时会有默认值 0, 而且无法消除 , 所以实体类中建议不要使用基本类型 .
10.@NameStyle 注解,用来配置对象名 / 字段和表名 / 字段之间的转换方式,该注解优先于全局配置 style ,可
选值:
normal: 使用实体类名 / 属性名作为表名 / 字段名
camelhump: 这是默认值,驼峰转换为下划线形式
uppercase: 转换为大写
lowercase: 转换为小写
*/
@Entity // 用于声明当前类是一个实体类
@Table (name= "tbl_users" ) // 用于声明当前类所对应的表名称
public class User implements Serializable {
@Id // 用于声明标识属性,对应表中的主键
@GeneratedValue (strategy = GenerationType .IDENTITY) 声明主键生成策略
private Long id ;
@Column // 如果属性名称和列名称不一致,则需要通过 @Column 进行配置对应的列名称
private String username ;
private String password ;
private Date birth ;
private Boolean sex ;
}
定义 mapper 接口
public interface UserMapper extends BaseMapper < User > {
}
针对 mapper 接口进行注册,一般是依赖自动扫描实现。可以在主类或者配置上添加一个注解配置

SpringBoot 针对 Junit 的单元测试有很好的支持 

 

需要控制器调用业务,业务再通过 Mapper 访问数据库,最终返回 JSON 字符串

3.3. 使用阿里巴巴 FastJson 的设置

3.3.1 jackson fastJson 的对比
有很多人已经习惯于使用阿里巴巴的 fastJson 来做项目中 json 转换的相关工作,比如目前项目中使用的就是
阿里的 fastJson

关于 fastJson jackson 的对比,网上有很多资料可以查看,主要是根据自己实际项目情况来选择合适的框架。
从扩展上来看, fastJson 没有 jackson 灵活,从速度或者上手难度来看, fastJson 可以考虑,项目中目前使用
的是阿里的 fastJson ,挺方便的。
3.3.2 fastJson 依赖导入
使用 fastJson 需要导入依赖
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
</dependency>
3.3.3 使用 fastJson 处理 null
使用 fastJson 时,对 null 的处理和 jackson 有些不同,需要继承 WebMvcConfigurationSupport 类或者实现
WebMvcConfiguration 接口,然后覆盖 configureMessageConverters 方法,在方法中可以选择对要实现 null
转换的场景,配置好即可。
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.alibaba.fastjson.support.config.FastJsonConfig;
import com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.MediaType;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.List;
@Configuration
public class fastJsonConfig extends WebMvcConfigurationSupport {
// 使用阿里 FastJson 作为 JSON MessageConverter
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
FastJsonHttpMessageConverter converter = new FastJsonHttpMessageConverter();
FastJsonConfig config = new FastJsonConfig();
config.setSerializerFeatures(
SerializerFeature.WriteMapNullValue, // 保留 map 空的字段
SerializerFeature.WriteNullStringAsEmpty, // String 类型的 null 转成 ""
SerializerFeature.WriteNullNumberAsZero, // Number 类型的 null 转成 0
SerializerFeature.WriteNullListAsEmpty, // List 类型的 null 转成 []
SerializerFeature.WriteNullBooleanAsFalse, // Boolean 类型的 null 转成 false
SerializerFeature.DisableCircularReferenceDetect); // 避免循环引用
converter.setFastJsonConfig(config);
converter.setDefaultCharset(Charset.forName("UTF-8"));
List<MediaType> mediaTypeList = new ArrayList<>();
// 解决中文乱码问题,相当于在 Controller 上的 @RequestMapping 中加了个属性 produces =

 

"application/json"
mediaTypeList.add(MediaType.APPLICATION_JSON);
converter.setSupportedMediaTypes(mediaTypeList);
converters.add(converter);
}
}
测试工具 postman

如果直接测试,则需要编写页面和 js 代码才能进行验证,可以使用 postman 避免这些繁琐的操作 

 

这里针对日期类型数据的格式转换会有报错。最终提交数据为
{"username":" 谢逊 ","sex":"true","birth":"1989-02-03","password":"666666"}

3.4. 封装统一返回的数据结构

在实际项目中,除了要封装数据之外,往往需要在返回的 json 中添加一些其他信息,比如返回一些状态码 code
【注意不是 response 的响应状态码】,返回一些 msg 给调用者,这样调用者可以根据 code 或者 msg 做一些
逻辑判断。所以在实际项目中,需要封装一个统一的 json 返回结构存储返回信息。
3.4.1 定义统一的 json 结构
由于封装的 json 数据的类型不确定,所以在定义统一的 json 结构时需要用到泛型。统一的 json 结构中属性包
括数据、状态码、提示信息即可,构造方法可以根据实际业务需求做相应的添加即可,一般来说,应该有默认
的返回结构,也应该有用户指定的返回结构。
public class JsonResult<T> {
private T data; // 需要传递的数据
private int code; // 用户自定义相应码,注意不是服务器响应状态码。如果不需要传递详细信息还可以使
boolean success;
private String msg; // 服务器回传信息
public JsonResult() { 若没有数据返回,默认状态码为 0 ,提示信息为:操作成功!
this.code = 0;
this.msg = " 操作成功! ";
}
public JsonResult(int code, String msg) { 若没有数据返回,可以人为指定状态码和提示信息
this.code = code;
this.msg = msg;
}
public JsonResult(T data) { 有数据返回时,状态码为 0 ,默认提示信息为:操作成功!
this.data = data;
this.code = 0;
this.msg = " 操作成功! ";
}
public JsonResult(T data, String msg) { 有数据返回,状态码为 0 ,人为指定提示信息
this.data = data;
this.code = 0;
this.msg = msg;
}
// 省略 get set 方法
}
建议写法,不一定最佳

3.4.2 修改 Controller 中的返回值类型及测试
由于 JsonResult 使用了泛型,所以所有的返回值类型都可以使用该统一结构,在具体的场景将泛型替换成具体
的数据类型即可,非常方便,也便于维护。在实际项目中,还可以继续封装,比如状态码和提示信息可以定义
一个枚举类型,以后只需要维护这个枚举类型中的数据即可。根据以上的 JsonResult 可以改写一下 Controller
@RestController
@RequestMapping("/jsonresult")
public class JsonResultController {
@RequestMapping("/user")
public JsonResult<User> getUser() {

 

User user = new User(1, " 闫峻 ", "123456");
return new JsonResult<>(user);
}
@RequestMapping("/list")
public JsonResult<List> getUserList() {
List<User> userList = new ArrayList<>();
User user1 = new User(1, " 闫峻 ", "123456");
User user2 = new User(2, " 死胖子 ", "123456");
userList.add(user1);
userList.add(user2);
return new JsonResult<>(userList, " 获取用户列表成功 ");
}
@RequestMapping("/map")
public JsonResult<Map> getMap() {
Map<String, Object> map = new HashMap<>(3);
User user = new User(1, " 闫峻 ", null);
map.put(" 作者信息 ", user);
map.put(" 博客地址 ", "http://blog.yan.com");
map.put("CSDN 地址 ", null);
map.put(" 粉丝数量 ", 4153);
return new JsonResult<>(map);
}
}
重新在浏览器中输入: localhost:8080/jsonresult/user 返回 json
{"code":0,"data":{"id":1,"password":"123456","username":" 闫峻 "},"msg":" 操作成功! "}
输入: localhost:8080/jsonresult/list ,返回 json 格式:
{"code":0, "data":[{"id":1, "password":"123456", "username":" 闫 峻 "}, {"id":2, "password":"123456",
"username":" 死胖子 "}], "msg":" 获取用户列表成功 "}
输入: localhost:8080/jsonresult/map ,返回 json 格式:
{"code":"0", "data":{" 作者信息 ":{"id":1, "password":"","username":" 闫峻 "},"CSDN 地址 ":null," 粉丝数量
":4153," 博客地址 ":"http://blog.yan.com"},"msg":" 操作成功! "}
通过封装,不但将数据通过 json 传给前端或者其他接口,还带上了状态码和提示信息,这在实际项目场景中
应用非常广泛。

4. 总结

这里主要是对 Spring Boot json 数据的返回做了详细的分析,从 Spring Boot 默认的 jackson 框架到阿里的
fastJson 框架,分别对它们的配置做了相应的描述。另外,结合实际项目情况,总结了实际项目中使用的 json
封装结构体,加入了状态码和提示信息,使得返回的 json 数据信息更加完整。
作业:熟悉基本的 SpringBoot 应用开发流程,博客账户和发学习总结

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值