学习材料
尚硅谷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有默认的,所以要修改:
重大阻碍: 在安装老师所说自动下载的时候报错了。一直以为是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><!--spring context依赖--><!--当你引入Spring Context依赖之后,表示将Spring的基础依赖引入了--><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>6.0.2</version></dependency><!--junit5测试--><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter-api</artifactId><version>5.3.1</version></dependency>
</dependencies>
然后创建了一个User类。
在resource里面创建了bean.xml用于配置。
在test里面进行了测试。
User类
public class User {public void add(){System.out.println("add......");}
}
bean.xml
<?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的对象交给Spring的IOC容器管理通过bean标签配置IOC容器所管理的bean属性:id:设置bean的唯一标识class:设置bean所对应类型的全类名--><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的对象交给Spring的IOC容器管理通过bean标签配置IOC容器所管理的bean属性:id:设置bean的唯一标识class:设置bean所对应类型的全类名--><bean id="helloWorld" class="com.atguigu.spring6.bean.HelloWorld"></bean></beans>
分析案例
老师讲解了三个问题:
- 底层是怎么创建对象的,是通过反射机制调用无参数构造方法吗?
- Spring是如何创建对象的呢?原理是什么?
- 把创建好的对象存储到一个什么样的数据结构当中了呢?
第一个问题就是显式地写一个无参构造器,然后输出一些信息就行。
第二个问题就是反射的知识。
@Testpublic 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下最流行的日志输入工具。
- 还是要再pom.xml里面引入依赖。
<!--log4j2的依赖--><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-core</artifactId><version>2.19.0</version></dependency><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-slf4j2-impl</artifactId><version>2.19.0</version></dependency>
-
然后再resource里面创建log4j2.xml文件。具体内容,老师给了。
-
运行原来的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 -
如何手动写日志?
public class HelloWorldTest {private Logger logger = LoggerFactory.getLogger(HelloWorldTest.class);@Testpublic void testHelloWorld(){ApplicationContext ac = new ClassPathXmlApplicationContext("beans.xml");HelloWorld helloworld = (HelloWorld) ac.getBean("helloWorld");helloworld.sayHello();logger.info("执行成功");}
}