Spring6-3.Spring 的入门程序

197 阅读4分钟

Spring 的入门程序

Spring 的 jar 文件

从 Spring 官网下载的 Spring FrameWrok 压缩包,解压后得到下面的文件

spinrg框架的内容.png

  • docs:Spring 框架的 API 帮助文档;
  • libs:Spring 框架的 jar 文件(用 Spring 框架就是用这些 jar 包);
  • schema:Spring 框架的 XML 配置文件相关的约束文件(设置 XML 允许使用哪些标签,标签有哪些属性等信息)。

打开libs目录,会看到很多jar包:

spring-core-5.3.9为例,与它相关的有三个 jar包:

spring-core-jar.png

  • spring-core-5.3.9.jar:字节码(这是支撑程序运行的 jar 包);
  • spring-core-5.3.9-javadoc.jar:代码中的注释;
  • spring-core-5.3.9-sources.jar:源码。

来看一下 spring 框架一共有哪些 jar 包:

JAR文件描述
spring-aop-5.3.9.jar这个jar 文件包含在应用中使用Spring 的AOP 特性时所需的类
spring-aspects-5.3.9.jar提供对AspectJ的支持,以便可以方便的将面向切面的功能集成进IDE中
spring-beans-5.3.9.jar这个jar 文件是所有应用都要用到的,它包含访问配置文件、创建和管理bean 以及进行Inversion ofControl / Dependency Injection(IoC/DI)操作相关的所有类。如果应用只需基本的IoC/DI 支持,引入spring-core.jar 及spring-beans.jar 文件就可以了。
spring-context-5.3.9.jar这个jar 文件为Spring 核心提供了大量扩展。可以找到使用Spring ApplicationContext特性时所需的全部类,JDNI 所需的全部类,instrumentation组件以及校验Validation 方面的相关类。
spring-context-indexer-5.3.9.jar虽然类路径扫描非常快,但是Spring内部存在大量的类,添加此依赖,可以通过在编译时创建候选对象的静态列表来提高大型应用程序的启动性能。
spring-context-support-5.3.9.jar用来提供Spring上下文的一些扩展模块,例如实现邮件服务、视图解析、缓存、定时任务调度等
spring-core-5.3.9.jarSpring 框架基本的核心工具类。Spring 其它组件要都要使用到这个包里的类,是其它组件的基本核心,当然你也可以在自己的应用系统中使用这些工具类。
spring-expression-5.3.9.jarSpring表达式语言。
spring-instrument-5.3.9.jarSpring3.0对服务器的代理接口。
spring-jcl-5.3.9.jarSpring的日志模块。JCL,全称为"Jakarta Commons Logging",也可称为"Apache Commons Logging"。
spring-jdbc-5.3.9.jarSpring对JDBC的支持。
spring-jms-5.3.9.jar这个jar包提供了对JMS 1.0.2/1.1的支持类。JMS是Java消息服务。属于JavaEE规范之一。
spring-messaging-5.3.9.jar为集成messaging api和消息协议提供支持
spring-orm-5.3.9.jarSpring集成ORM框架的支持,比如集成hibernate,mybatis等。
spring-oxm-5.3.9.jar为主流O/X Mapping组件提供了统一层抽象和封装,OXM是Object Xml Mapping。对象和XML之间的相互转换。
spring-r2dbc-5.3.9.jarReactive Relational Database Connectivity (关系型数据库的响应式连接) 的缩写。这个jar文件是Spring对r2dbc的支持。
spring-test-5.3.9.jar对Junit等测试框架的简单封装。
spring-tx-5.3.9.jar为JDBC、Hibernate、JDO、JPA、Beans等提供的一致的声明式和编程式事务管理支持。
spring-web-5.3.9.jarSpring集成MVC框架的支持,比如集成Struts等。
spring-webflux-5.3.9.jarWebFlux是 Spring5 添加的新模块,用于 web 的开发,功能和 SpringMVC 类似的,Webflux 使用当前一种比较流程响应式编程出现的框架。
spring-webmvc-5.3.9.jarSpringMVC框架的类库
spring-websocket-5.3.9.jarSpring集成WebSocket框架时使用

注意:

如果只是想用 Spring 的 IoC 功能,使用 maven 仅需要引入 spring-context 即可(spring-context 会关联引用 spring-core 和 spring-beans 这两个 jar 包)。

第一个 Spring 程序

  1. 把创建好的对象存储到一个什么样的数据结构当中了呢?

Spring 把创建好的对象存储到了一个 Map 当中

<bean id="userBean" class="com.powernode.spring6.bean.User"/>
<bean id="vipBean" class="com.powernode.spring6.bean.Vip"/>

Map 结构如下

spring_map.png

  1. 像这样的beans.xml文件可以有多个吗?

再创建一个spring配置文件,起名:spring.xml

public class Spring6Test {
​
    @Test
    public void testFirst(){
      // 初始化Spring容器上下文(解析beans.xml文件,创建所有的bean对象)
      // 这个构造函数接受一个不定长的参数
      ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml","spring.xml");
​
      // 根据id获取bean对象
      Object userBean = applicationContext.getBean("userBean");
      Object vipBean = applicationContext.getBean("vipBean");
​
      System.out.println(userBean);
      System.out.println(vipBean);
    }
}

3. getBean()方法返回的类型是Object,如果访问子类的特有属性和方法时,还需要向下转型,有其它办法可以解决这个问题吗?

User user = applicationContext.getBean("userBean", User.class);

4. ApplicationContext的超级父接口BeanFactory

BeanFactory是Spring容器的超级接口。ApplicationContext是BeanFactory的子接口。

Spring 的 Ioc 容器底层实际上是用了工厂模式,另外还用了 XML 解析和反射机制

BeanFactory beanFactory = new ClassPathXmlApplicationContext("spring.xml");
Object vipBean = beanFactory.getBean("vipBean");
System.out.println(vipBean);

5. Spring 创建对象的时刻

Spring 不实在调用 getBean() 的时候创建对象,而是在执行 new ClassPathXmlApplicationContext() 的时候就会实例化对象

Spring6 启用 Log4j2 日志框架

从 Spring5 以后,Spring 框架支持集成的日志框架是 Log4j2。

  1. 引入 Log4j2 依赖
<!--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>

2. 在类的根路径下提供 Log4j2.xml 配置文件(文件名固定为 log4j2.xml,且文件必须放在类根路径下)

<?xml version="1.0" encoding="UTF-8"?><configuration>
​
    <loggers>
        <!--
            level指定日志级别,从低到高的优先级:
                ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < OFF
        -->
        <root level="DEBUG">
            <appender-ref ref="spring6log"/>
        </root>
    </loggers>
​
    <appenders>
        <!--输出日志信息到控制台-->
        <console name="spring6log" target="SYSTEM_OUT">
            <!--控制日志输出的格式-->
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss SSS} [%t] %-3level %logger{1024} - %msg%n"/>
        </console>
    </appenders></configuration>

3. 如何在代码中使用 log4j2 记录日志信息?

Logger logger = LoggerFactory.getLogger(FirstSpringTest.class);
logger.info("我是一条日志消息");
logger.debug("我是一条调试信息");
logger.error("我是一条错误");