Spring5框架 笔记总结
Posted IT_Holmes
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring5框架 笔记总结相关的知识,希望对你有一定的参考价值。
文章目录
- 1. Spring5 框架 新特性
- 2. Spring5 整合Log4j2版本(新特性 2)
- 3. Spring5 核心容器支持@Nullable注解 (新特性 3)
- 4. Spring5 核心容器 支持函数式风格(GenericApplicationContext , 新特性 4)
- 5. Spring5 支持整合JUnit5单元测试框架(新特性 5)
- 6. Spring5 框架新的模块 SpringWebFlux(新特性 6)
1. Spring5 框架 新特性
整个Spring5 框架的代码基于Java8,运行时兼容JDK9,其中许多不建议使用的类和方法在代码库中删除。(新特性 1)
2. Spring5 整合Log4j2版本(新特性 2)
Spring 5 框架自带了通用的日志封装,也可以自己整合其他的日志工具,例如:log4j2 日志。
- Spring 5 已经移除Log4jConfigListener , 官方建议使用Log4j2版本。因此如果在Spring5中使用log4j的 1 版本的话,需要把Spring的版本降到4版本才可以!
- 因此,这里我们来整合Spring5 的Log4j2版本。
注意:Spring4以及之前版本是可以直接使用log4j版本的,但是Spring5只能使用log4j2版本,记住!
Spring5 框架整合Log4j2
第一步:导入jar包。
第二步:创建log4j2.xml配置文件,注意这个名字是固定的!(小写的log4j.xml文件)。
<?xml version="1.0" encoding="UTF-8"?>
<!--日志级别以及优先级大小为: OFF < FATAL < ERROR < WARN < INFO < DEBUG < TRACE < ALL , 意思就是越往右边显示的越多,优先级越高。-->
<!--例如:设置为DEBUG,那么显示就会显示DEBUG以及比DEBUG优先级小(ERROR < WARN < INFO < DEBUG)的信息。-->
<!--Configuration后面的status用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,可以看到log4j2内部各种详细输出-->
<configuration status="DEBUG">
<!--先定义所有的appender-->
<appenders>
<!--输出日志信息到控制台-->
<console name="Console" target="SYSTEM_OUT">
<!--控制日志输出的格式-->
<PatternLayout charset="GBK" pattern="%dHH:mm:ss.SSS [%t] %-5level %logger36 - %msg%n"/>
</console>
</appenders>
<!--然后定义loggers,只有定义了logger,并且引入appender,appender才会生效-->
<loggers>
<!--root:用于指定项目的根日志,如果没有单独指定Logger,则会使用root作为默认的日志输出-->
<root level="debug"> <!--大小写都可以 -->
<AppenderRef ref="Console"/>
</root>
</loggers>
</configuration>
还有一种方式,就是通过log4j-slf4j-impl包里面的logger类来实现 :
Logger log = LoggerFactory.getLogger(UserLog.class);
我们创建一个UserLog类来试试:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class UserLog
//注意这里的logger是org.slf4j的logger,不要混淆!
private static final Logger log = LoggerFactory.getLogger(UserLog.class);
public static void main(String[] args)
log.info("hello log4j2 ~ info");
log.warn("hello log4j2 ~ warn");
效果如下:也是会打印出来的!
3. Spring5 核心容器支持@Nullable注解 (新特性 3)
Spring 5 框架核心容器支持@Nullable注解:
-
@Nullable 注解 可以使用在方法上面,属性上面,参数上面,表示方法返回可以为空,属性值可以为空,参数值可以为空。
-
@Nullable注解:用在方法上面,表示该方法返回值可以为空。
-
@Nullable注解:用在方法参数上面,表示该方法参数可以为空。
-
@Nullable注解:用在属性变量上面,表该属性变量可以为空。
在源码中,有很多使用@Nullable的例子,如下图:
4. Spring5 核心容器 支持函数式风格(GenericApplicationContext , 新特性 4)
其实,所谓的函数式风格,就是通过函数代码的方式创建对象,从而提交给spring进行管理。
创建一个User类,测试类:
package com.itholmes.User;
public class User
创建一个test类,来实现函数式代码创建对象,提交给spring的效果:
package Test;
import com.itholmes.User.User;
import org.junit.Test;
import org.springframework.context.support.GenericApplicationContext;
public class Test4
//函数式风格创建对象,交给spring进行管理的步骤
@Test
public void testGenericApplicationContext()
//1.创建GenericApplicationContext对象
GenericApplicationContext context = new GenericApplicationContext();
//2.调用context的方法对象注册
//context.refresh()作用是把context的内容清空。
context.refresh();
//() -> new User(); 是Lambda表达式
context.registerBean(User.class,() -> new User());
//3.获取在spring注册的对象
//这里我们不能直接通过像xml和注解那样,直接首字母小写的user就能获取,必须加上包名对应的路径如下:
User user = (User)context.getBean("com.itholmes.User.User");
System.out.println(user);
@Test
public void testGenericApplicationContext2()
GenericApplicationContext context = new GenericApplicationContext();
context.refresh();
//我们可以通过在这里添加参数beanName来给他起名字,因为源码这里是@Nullable注解类型,因此,有时候该参数可以为空。
context.registerBean("user123",User.class,() -> new User());
User user = (User)context.getBean("user123");
System.out.println(user);
5. Spring5 支持整合JUnit5单元测试框架(新特性 5)
Spring5框架,也支持整合JUnit4,只不过相比较其他Spring版本框架,又出了整合JUnit5的测试。
5.1 Spring5 整合JUnit4
Spring5 整合JUnit4:
第一步:引入Spring 相关针对测试的依赖。
第二步:创建测试类,使用JUint4的注解方式完成。
package Test;
import com.itholmes.service.UserService;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
//这一步,相当于@RunWith(xxx) 或 @RunWith(value=xxx):来指定我们使用哪个junit的版本,注意这里是class文件形式。
@RunWith(SpringJUnit4ClassRunner.class)
//这一步,相当于ApplicationContext context = new ClassPathXmlApplicationContext("beans2.xml");
@ContextConfiguration("classpath:beans2.xml")
public class JTest4
//上面加载了配置文件,这里我们可以直接获取就可以了。
//这一步,相当于UserService bean = context.getBean("userService", UserService.class);
@Autowired
private UserService userService;
@Test
public void test1()
//在这我们就可以直接调用了。
userService.accountMoney();
5.2 Spring5 整合JUnit5
整合JUnit5的步骤:
第一步:引入JUnit5的jar包或依赖。
第二步:创建测试类,使用JUnit5中的注解来完成。
package Test;
import com.itholmes.service.UserService;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit.jupiter.SpringExtension;
//@ExtendWith(SpringExtension.class):注解的一个引用
@ExtendWith(SpringExtension.class)
@ContextConfiguration("classpath:beans2.xml")
public class JTest5
@Autowired
private UserService userService;
@Test//注意这里的Test是org.junit.jupiter.api.Test中JUnit5的test
public void test1()
userService.accountMoney();
也可以使用复合注解@SpringJUnitConfig(locations = “xxx.xml”)来复合一下:
package Test;
import com.itholmes.service.UserService;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit.jupiter.SpringExtension;
import org.springframework.test.context.junit.jupiter.SpringJUnitConfig;
//@ExtendWith(SpringExtension.class)
//@ContextConfiguration("classpath:beans2.xml")
//@SpringJUnitConfig(locations = "classpath:beans2.xml")就是上面两个注解的复合注解
@SpringJUnitConfig(locations = "classpath:beans2.xml")
public class JTest5
@Autowired
private UserService userService;
@Test//注意这里的Test是org.junit.jupiter.api.Test中JUnit5的test
public void test1()
userService.accountMoney();
6. Spring5 框架新的模块 SpringWebFlux(新特性 6)
学习 SpringWebFlux必须要掌握Spring MVC , Spring Boot, Java8新特性,之后再补充!
以上是关于Spring5框架 笔记总结的主要内容,如果未能解决你的问题,请参考以下文章
Spring5学习笔记 — “AOP操作—AspectJ注解”