深入探索Spring Boot基础功能(二):JSON数据处理与日志记录

在这里插入图片描述

博主 默语带您 Go to New World.
个人主页—— 默语 的博客👦🏻
《java 面试题大全》
《java 专栏》
🍩惟余辈才疏学浅,临摹之作或有不妥之处,还请读者海涵指正。☕🍭
《MYSQL从入门到精通》数据库是开发者必会基础之一~
🪁 吾期望此文有资助于尔,即使粗浅难及深广,亦备添少许微薄之助。苟未尽善尽美,敬请批评指正,以资改进。!💻⌨


🌟 深入探索Spring Boot基础功能(二):JSON数据处理与日志记录

摘要

大家好,我是默语,一个热爱技术分享的博主。今天我们将深入探讨Spring Boot的基础功能,包括如何处理JSON数据和使用slf4j进行日志记录。这篇博客将详细介绍Spring Boot在这些方面的强大能力,通过实际代码案例演示,为大家提供实用的开发技巧。希望这篇文章能为你的Spring Boot学习之旅提供有价值的参考。✨

引言

在现代Web应用开发中,JSON数据处理和日志记录是必不可少的两个环节。Spring Boot不仅提供了简洁高效的JSON处理机制,还集成了slf4j日志系统,方便开发者进行日志管理。本文将带你深入了解这两个核心功能的实现方式。

正文内容

第二章:Spring Boot基础功能

1. 🌐 Spring Boot返回JSON数据及数据封装

在Web应用中,JSON是前后端交互的常用数据格式。Spring Boot对JSON数据处理提供了默认支持,使用起来非常方便。

Spring Boot默认对JSON的处理

Spring Boot默认使用Jackson库来处理JSON数据,以下是一个简单的示例。

创建User实体类

首先,创建一个User实体类:

public class User {
    private String name;
    private int age;

    // getters and setters
}
创建Controller类

然后,创建一个Controller类,用于返回User对象的JSON表示:

@RestController
public class UserController {

    @GetMapping("/user")
    public User getUser() {
        User user = new User();
        user.setName("默语");
        user.setAge(25);
        return user;
    }
}
测试不同数据类型返回的JSON

我们可以通过不同的请求返回不同的数据类型,如字符串、对象、集合等:

@GetMapping("/string")
public String getString() {
    return "Hello, Spring Boot!";
}

@GetMapping("/list")
public List<User> getUserList() {
    List<User> users = new ArrayList<>();
    users.add(new User("默语", 25));
    users.add(new User("技术分享", 30));
    return users;
}
Jackson中对null的处理

默认情况下,Jackson会序列化所有非空字段。我们可以通过配置来改变这一行为:

@JsonInclude(JsonInclude.Include.NON_NULL)
public class User {
    private String name;
    private Integer age;

    // getters and setters
}
使用阿里巴巴FastJson的设置

阿里巴巴的FastJson是另一个流行的JSON库,性能较好。接下来,我们介绍如何在Spring Boot中使用FastJson。

Jackson和FastJson的对比

Jackson和FastJson各有优劣。Jackson功能全面,社区支持广泛;FastJson性能优异,使用简单。

FastJson依赖导入

pom.xml中添加FastJson依赖:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.76</version>
</dependency>
使用FastJson处理null

配置FastJson在序列化时忽略null值:

@Configuration
public class FastJsonConfig {

    @Bean
    public HttpMessageConverters fastJsonHttpMessageConverters() {
        FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter();
        FastJsonConfig fastJsonConfig = new FastJsonConfig();
        fastJsonConfig.setSerializerFeatures(SerializerFeature.PrettyFormat, 
                                             SerializerFeature.WriteMapNullValue,
                                             SerializerFeature.WriteNullStringAsEmpty,
                                             SerializerFeature.WriteNullNumberAsZero);
        fastConverter.setFastJsonConfig(fastJsonConfig);
        return new HttpMessageConverters(fastConverter);
    }
}
封装统一返回的数据结构

为了提高接口的一致性,我们可以封装一个统一的JSON返回结构。

定义统一的JSON结构

定义一个统一的响应类:

public class ApiResponse<T> {
    private int code;
    private String message;
    private T data;

    // constructors, getters, and setters
}
修改Controller中的返回值类型及测试

修改Controller返回统一的ApiResponse结构:

@GetMapping("/user")
public ApiResponse<User> getUser() {
    User user = new User("默语", 25);
    return new ApiResponse<>(200, "成功", user);
}
总结

通过上述内容,我们了解了如何在Spring Boot中处理JSON数据,以及如何使用不同的JSON库进行数据序列化。统一的数据返回结构有助于接口的维护和使用。


2. 📄 Spring Boot使用slf4j进行日志记录

日志记录是应用程序开发中的重要部分,slf4j是Java中广泛使用的日志框架。Spring Boot默认集成了slf4j和logback。

slf4j介绍

slf4j(Simple Logging Facade for Java)是一个简单的日志门面,允许使用者在不修改代码的情况下选择具体的日志实现,如logback、log4j等。

application.yml中对日志的配置

application.yml文件中进行日志配置:

logging:
  level:
    root: INFO
    com.example: DEBUG
  file:
    path: /var/log/myapp/
    name: spring.log
logback.xml配置文件解析

logback是slf4j的原生实现,可以通过logback.xml进行详细配置。

定义日志输出格式和存储路径

src/main/resources目录下创建logback.xml文件:

<configuration>
    <property name="LOG_PATH" value="/var/log/myapp/"/>
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${LOG_PATH}/spring.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_PATH}/spring-%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>30</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
    </appender>
</configuration>
定义控制台输出

添加一个控制台输出的appender:

<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
    </encoder>
</appender>
定义日志文件的相关参数

可以设置日志文件的大小和保留策略:

<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
    <fileNamePattern>${LOG_PATH}/spring-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
    <maxFileSize>10MB</maxFileSize>
    <maxHistory>30</maxHistory>
</rollingPolicy>
定义日志输出级别

设置不同包的日志级别:

<logger name="com.example" level="DEBUG"/>
<root level="INFO">
    <appender-ref ref="CONSOLE"/>
    <appender-ref ref="FILE"/>
</root>
使用Logger在项目中打印日志

在代码中使用slf4j记录日志:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class LogController {

    private static final Logger logger = LoggerFactory.getLogger(LogController.class);

    @GetMapping("/log")
    public String logTest() {
        logger.info("This is an INFO log message");
        logger.debug("This is a DEBUG log message");
        logger.error("This is an ERROR log message");
        return "Check the logs for messages";
    }
}
总结

通过这部分内容,我们学习了如何在Spring Boot中配置和使用slf4j进行日志记录,并通过logback进行详细配置。日志记录有助于我们更好地监控和调试应用程序。

🤔 QA环节

问题:如何选择合适的JSON库?

回答:选择JSON库应根据具体需求和项目特点。Jackson功能全面,适合大多数场景;FastJson性能优秀,适用于对性能要求较高的项目。

小结

本章详细介绍了Spring Boot处理JSON数据和日志记录的实现方法。这些功能在实际开发中非常实用,希望你能从中受益。

表格总结

主题关键点
JSON数据处理默认使用Jackson,支持FastJson,封装统一返回结构
日志记录使用slf4j,配置application.yml和logback.xml,定义日志级别和输出格式

未来展望

在接下来的文章中,我们将继续探讨Spring Boot的

高级功能,包括数据库集成、事务管理、异步处理等,帮助你全面掌握Spring Boot的开发技巧。

参考资料

  1. Spring Boot官方文档
  2. Jackson官网
  3. FastJson官网
  4. slf4j官网
  5. logback官网

希望这篇文章对你有所帮助,欢迎在评论区留言讨论!💬


默语博主,与你一起探索技术的奥秘! 🌟

在这里插入图片描述


🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🍁🐥

如对本文内容有任何疑问、建议或意见,请联系作者,作者将尽力回复并改进📓;(联系微信:Solitudemind )

点击下方名片,加入IT技术核心学习团队。一起探索科技的未来,共同成长。

在这里插入图片描述

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

默 语

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值