Spring5框架 笔记总结

Posted IT_Holmes

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring5框架 笔记总结相关的知识,希望对你有一定的参考价值。

文章目录

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框架 笔记总结

Spring5学习笔记 — “AOP操作—AspectJ注解”

Spring5学习笔记 — “AOP操作—AspectJ注解”

Spring5框架 笔记总结

Spring5框架 笔记总结

Spring | Spring5学习笔记 #yyds干货盘点#