Spring6学习技术|简要介绍+安装环境+入门案例+log4j2日志

学习材料

尚硅谷Spring零基础入门到进阶,一套搞定spring6全套视频教程(源码级讲解)
碎碎念一下吧,javaWeb跟完了全程。还是感觉啥也不知道,啥也没学会。2025年春天能找到实习吗?真的好担心。

环境安装

纠结跟spring5还是spring6,思索一下,还是跟spring6吧。原因是spring5的教程里面我找不到视频里的spring安装路径。
spring6要求的环境如下:

(1)IDEA开发工具:2022.1.2
(2)JDK:Java17 (Spring6要求JDK最低版本是Java17)
(3)Spring:6.0.2

关于JDK。原来跟韩顺平老师的课程的时候安装过jdk8,所以这里选择安装多版本的教程。
环境变量配置(同时安装多个JDK)
关于maven,我从来没有接触过,这到底是一个什么东西,比较小白地跟着教程安装了。这里修改setting.xml时,修改到阿里云的镜像,测试在idea里面会报错,所以就用默认的。(3.9版本)
intellij IDEA安装Maven详细过程
在安装完这些之后,jdk比较好选择,只要在创建项目的时候用到就好,麻烦的是Maven,因为idea有默认的,所以要修改:
Spring6学习技术|简要介绍+安装环境+入门案例+log4j2日志_第1张图片
重大阻碍: 在安装老师所说自动下载的时候报错了。一直以为是setting.xml出错,所以idea默认的Maven和自己下载Maven一直反复选择。最后在一篇帖子里面得到了答案,是idea版本和Maven版本不一致。参考。所以安装了最新版idea(这里有条件可以申请教育免费的)。

记录一下什么是Maven?目前能感受到的就是不用手动引入jar包了,嘿嘿。
Maven是什么? Maven的概念+作用+仓库的介绍+常用命令

Spring

怎么说,文字部分就很抽象,没怎么听懂。
轻量级的开源的框架。核心模块:IoC和AOP。

IoC:Inverse of Control 的简写,译为“控制反转”,指把创建对象过程交给 Spring 进行管理。(入门案例里展示了这个功能)
AOP:Aspect Oriented Programming 的简写,译为“面向切面编程”。AOP 用来封装多个类的公共行为,将那些与业务无关,却为业务模块所共同调用的逻辑封装起来,减少系统的重复代码,降低模块间的耦合度。另外,AOP 还解决一些系统层面上的问题,比如日志、事务、权限等。

一个入门案例

首先整个项目spring6创建了一个spring6-first的模块。
然后编写了spring6-first的pom.xml。引入了依赖。

<dependencies>
    
    
    <dependency>
        <groupId>org.springframeworkgroupId>
        <artifactId>spring-contextartifactId>
        <version>6.0.2version>
    dependency>

    
    <dependency>
        <groupId>org.junit.jupitergroupId>
        <artifactId>junit-jupiter-apiartifactId>
        <version>5.3.1version>
    dependency>
dependencies>

然后创建了一个User类。
在resource里面创建了bean.xml用于配置。
在test里面进行了测试。
Spring6学习技术|简要介绍+安装环境+入门案例+log4j2日志_第2张图片
User类

public class User {
    public void add(){
        System.out.println("add......");
    }
}

bean.xml


<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    
    <bean id="user" class="com.zy.spring6.User">bean>
    
beans>

测试

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    <!--
    配置HelloWorld所对应的bean,即将HelloWorld的对象交给SpringIOC容器管理
    通过bean标签配置IOC容器所管理的bean
    属性:
        id:设置bean的唯一标识
        class:设置bean所对应类型的全类名
	-->
    <bean id="helloWorld" class="com.atguigu.spring6.bean.HelloWorld"></bean>
    
</beans>

分析案例

老师讲解了三个问题:

  1. 底层是怎么创建对象的,是通过反射机制调用无参数构造方法吗?
  2. Spring是如何创建对象的呢?原理是什么?
  3. 把创建好的对象存储到一个什么样的数据结构当中了呢?
    第一个问题就是显式地写一个无参构造器,然后输出一些信息就行。
    Spring6学习技术|简要介绍+安装环境+入门案例+log4j2日志_第3张图片

第二个问题就是反射的知识。

    @Test
    public void testUserReflect() throws Exception {
        //获取类的Class对象
        Class clazz = Class.forName("com.zy.spring6.User");
        //调用方法创建对象
        User user = (User) clazz.getDeclaredConstructor().newInstance();
        System.out.println(user);
    }
}

第三个问题就是到源代码里去看(老师直接给了答案,就是Map<唯一标识id,value类的有关信息>)

bean对象最终存储在spring容器中,在spring源码底层就是一个map集合,存储bean的map在DefaultListableBeanFactory类中:

Log4j2日志框架

在项目开发中,日志十分的重要,不管是记录运行情况还是定位线上问题,都离不开对日志的分析。日志记录了系统行为的时间、地点、状态等相关信息,能够帮助我们了解并监控系统状态,在发生错误或者接近某种危险状态时能够及时提醒我们处理,同时在系统产生问题时,能够帮助我们快速的定位、诊断并解决问题。
Apache Log4j2是一个开源的日志记录组件,使用非常的广泛。在工程中以易用方便代替了 System.out 等打印语句,它是JAVA下最流行的日志输入工具。

  1. 还是要再pom.xml里面引入依赖。

        <dependency>
            <groupId>org.apache.logging.log4jgroupId>
            <artifactId>log4j-coreartifactId>
            <version>2.19.0version>
        dependency>
        <dependency>
            <groupId>org.apache.logging.log4jgroupId>
            <artifactId>log4j-slf4j2-implartifactId>
            <version>2.19.0version>
        dependency>
  1. 然后再resource里面创建log4j2.xml文件。具体内容,老师给了。

  2. 运行原来的test函数。
    遇到了报错,解决方法警告: TestEngine with ID ‘junit-vintage’ failed to discover tests 。java.lang.NoSuchMethodError: org.ju…
    【SpringBoot测试Test报错】TestEngine with ID ‘junit-jupiter‘ failed to discover test

  3. 如何手动写日志?

public class HelloWorldTest {

    private Logger logger = LoggerFactory.getLogger(HelloWorldTest.class);

    @Test
    public void testHelloWorld(){
        ApplicationContext ac = new ClassPathXmlApplicationContext("beans.xml");
        HelloWorld helloworld = (HelloWorld) ac.getBean("helloWorld");
        helloworld.sayHello();
        logger.info("执行成功");
    }
}

你可能感兴趣的:(Java技术学习,学习,spring)