前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >2、Spring6 入门

2、Spring6 入门

作者头像
叫我阿杰好了
发布于 2023-10-17 07:10:18
发布于 2023-10-17 07:10:18
18700
代码可运行
举报
运行总次数:0
代码可运行

1、环境要求

  • JDK:Java17+(Spring6要求JDK最低版本是Java17)
  • Maven:3.6+
  • Spring:6.0.2

2、构建模块

2.1 构建父模块spring6

点击“Create”

2.2 构建子模块spring-first

点击 Create 完成.

3、程序开发

3.1 引入依赖

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<dependencies>
    <!--spring context依赖-->
    <!--当你引入Spring Context依赖之后,表示将Spring的基础依赖引入了-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>6.0.11</version>
    </dependency>

    <!--junit5测试-->
    <dependency>
        <groupId>org.junit.jupiter</groupId>
        <artifactId>junit-jupiter-api</artifactId>
        <version>5.3.1</version>
    </dependency>
</dependencies>

查看依赖:

3.2 创建java类

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.jie.spring6;

/**
 * @author Administrator
 */
public class HelloWorld {

    public void sayHello() {
        System.out.println("helloworld");
    }
}

3.3 创建配置文件

在resources目录创建一个 Spring 配置文件 bean.xml(配置文件名称可随意命名,如:springs.xml)

 以前我们创建对象的方式是通过

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 HelloWorld helloWorld = new HelloWorld();

的方式,但是现在我们可以把创建对象的这个过程,在spring中进行实现。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?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.jie.spring6.HelloWorld"/>

</beans>

 3.4 创建测试类测试

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.jie.spring6;

import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

/**
 * @author JIE
 * @version 1.0
 * @description: 测试类
 * @date 2023/8/30 9:20
 */
public class HelloWorldTest {

    @Test
    public void testHelloWorld() {
        // 创建一个ClassPathXmlApplicationContext对象,加载名为beans.xml的配置文件
        ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");

        // 获取名为helloWorld的Bean
        HelloWorld helloworld = (HelloWorld) ac.getBean("helloWorld");

        // 调用sayHello方法
        helloworld.sayHello();
    }

}

3.5 运行测试程序

4、程序分析

第一个问题:spring 底层是如何创建对象的,是通过反射机制调用无参构造方法吗?

首先修改HelloWorld类:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.jie.spring6;

/**
 * @author Administrator
 */
public class HelloWorld {

    public HelloWorld() {
        System.out.println("无参构造方法调用");
    }


    public void sayHello() {
        System.out.println("helloworld");
    }
}

 执行测试结果:

测试得知:创建对象时确实调用了无参数构造方法。

那 Spring是如何创建对象的呢?原理是什么?

打开我们的测试类。

然后我们点开bean.xml 。spring 会如何解析我们的xml文件内容呢?

我们这个bean标签是不是有id (唯一标识),class 是 类的全路径。

那我们拿到的类的全路径,接下来可以做什么?

那就是我们的 第四步 使用反射根据类的全路径创建对象。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 Class clazz = Class.forName("com.jie.spring6.HelloWorld");
 //Object obj = clazz.newInstance();
 Object object = clazz.getDeclaredConstructor().newInstance();

接下来就是创建完对象后,对象存放在哪里?

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

我们 在 idea 中 按两下 shift 。

 在弹出的窗口中输入 DefaultListableBeanFactory。然后选择 DefaultListableBeanFactory.java 就能跳到 DefaultListableBeanFactory 类中了,在这个类中我们找到 beanDefinitionMap 这个属性。

Spring容器加载到Bean类时 , 会把这个类的描述信息, 以包名加类名的方式存到beanDefinitionMap 中, Map<String,BeanDefinition> , 其中 String是Key , 默认是类名首字母小写 , BeanDefinition , 存的是类的定义(描述信息) , 我们通常叫BeanDefinition接口为 : bean的定义对象。

5、启用Log4j2日志框架

5.1 Log4j2日志概述

在项目开发中,日志十分的重要,不管是记录运行情况还是定位线上问题,都离不开对日志的分析。

日志记录了系统行为的时间、地点、状态等相关信息,能够帮助我们了解并监控系统状态,在发生错误或者接近某种危险状态时能够及时提醒我们处理,同时在系统产生问题时,能够帮助我们快速的定位、诊断并解决问题。

Apache Log4j2是一个开源的日志记录组件,使用非常的广泛。

在工程中以易用方便代替了 System.out 等打印语句,它是JAVA下最流行的日志输入工具。

Log4j2主要由几个重要的组件构成:

  1. 日志信息的优先级,日志信息的优先级从高到低有TRACE < DEBUG < INFO < WARN < ERROR < FATAL
    1. TRACE:追踪,是最低的日志级别,相当于追踪程序的执行
    2. DEBUG:调试,一般在开发中,都将其设置为最低的日志级别
    3. INFO:信息,输出重要的信息,使用较多
    4. WARN:警告,输出警告的信息
    5. ERROR:错误,输出错误信息
    6. FATAL:严重错误
  2. 这些级别分别用来指定这条日志信息的重要程度;级别高的会自动屏蔽级别低的日志,也就是说,设置了WARN的日志,则INFO、DEBUG的日志级别的日志不会显示
  3. 日志信息的输出目的地,日志信息的输出目的地指定了日志将打印到控制台还是文件中
  4. 日志信息的输出格式,而输出格式则控制了日志信息的显示内容。

5.2 引入Log4j2依赖

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 <!--log4j2的依赖-->
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.20.0</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-slf4j2-impl</artifactId>
    <version>2.20.0</version>
</dependency>

5.3 加入日志配置文件

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <loggers>
        <!--
            level指定日志级别,从低到高的优先级:
                TRACE < DEBUG < INFO < WARN < ERROR < FATAL
                trace:追踪,是最低的日志级别,相当于追踪程序的执行
                debug:调试,一般在开发中,都将其设置为最低的日志级别
                info:信息,输出重要的信息,使用较多
                warn:警告,输出警告的信息
                error:错误,输出错误信息
                fatal:严重错误
        -->
        <root level="DEBUG">
            <appender-ref ref="spring6log"/>
            <appender-ref ref="RollingFile"/>
            <appender-ref ref="log"/>
        </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>

        <!--文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,适合临时测试用-->
        <File name="log" fileName="F:/zuoMian/logs/test.log" append="false">
            <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </File>

        <!-- 这个会打印出所有的信息,
            每次大小超过size,
            则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,
            作为存档-->
        <RollingFile name="RollingFile" fileName="F:/zuoMian/logs/app.log"
                     filePattern="log/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log.gz">
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <SizeBasedTriggeringPolicy size="50MB"/>
            <!-- DefaultRolloverStrategy属性如不设置,
            则默认为最多同一文件夹下7个文件,这里设置了20 -->
            <DefaultRolloverStrategy max="20"/>
        </RollingFile>
    </appenders>
</configuration>

这种文件内容格式网上有很多,大家可以直接去搜索一下,然后 复制 + 粘贴 使用即可。

5.4 测试

运行原测试程序

运行原测试程序,多了spring打印日志。

5.5 使用日志

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.jie.spring6;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @author Administrator
 */
public class HelloWorld {

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

    public HelloWorld() {
        logger.info("无参构造方法调用");
    }


    public void sayHello() {
        logger.info("HelloWorld");
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-10-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
python装饰器的学习
在python中,装饰器是一种增加函数功能的简单方法,利用装饰器功能可以很快的给不同的函数插入相同的功能。
无涯WuYa
2018/10/25
4180
python装饰器的学习
Python进阶之强大的装饰器 Decorators (一)
这篇文章主要介绍 decorator(装饰器),在开始介绍 decorator 前,要先有一个观念,就是在 python 中,函数是对象,可以将它们分配给变量和传递给其他函数并从其他函数返回,可以在其他函数中定义函数,并且子功能可以捕获父功能的本地状态。
用户4945346
2020/06/16
2900
Python函数装饰器基础知识
函数装饰器是Python语言最优秀的设计之一,它以非常简洁的方式增强了函数的行为,让崎岖不平之路变得平坦顺畅。
dongfanger
2022/05/09
2490
Python函数装饰器基础知识
【从零学习python 】32.装饰器的作用(一)
装饰器是程序开发中经常会用到的一个功能,用好了装饰器,开发效率如虎添翼,所以这也是Python面试中必问的问题。但对于好多初次接触这个知识的人来讲,这个功能有点绕,自学时直接绕过去了,然后面试问到了就挂了,因为装饰器是程序开发的基础知识,这个都不会,别跟人家说你会Python, 看了下面的文章,保证你学会装饰器。
全栈若城
2024/02/29
920
看完这篇文章还会不懂Python装饰器?掐死小编吧
1. 必备 #### 第一波 #### def foo(): print('foo') foo #表示是函数 foo() #表示执行foo函数 #### 第二波 #### def foo(): print('foo') foo = lambda x: x + 1 foo(1) # 执行下面的lambda表达式,而不再是原来的foo函数,因为函数 foo 被重新定义了 2. 需求来了 初创公司有N个业务部门,1个基础平台部门,基础平台负责提供底层的功能,如:数据库操作、r
崔庆才
2018/06/25
5810
看完这篇文章还不懂Python装饰器?
初创公司有N个业务部门,1个基础平台部门,基础平台负责提供底层的功能,如:数据库操作、redis调用、监控API等功能。业务部门使用基础功能时,只需调用基础平台提供的功能即可。如下:
QQ1622479435
2018/11/14
5080
Python3中的装饰器
def foo(): print("第一次定义的foo()函数") def foo(): print("第二次定义的foo()函数") foo() # 结果 第二次定义的foo()函数
py3study
2020/01/10
5910
Python随笔(四)、python基础
05 python s12 day4 迭代器原理及使用 什么是迭代: 可以直接作用于for循环的对象统称为可迭代对象(Iterable)。* 可以被next()函数调用并不断返回下一个值的对象称为迭代器(Iterator)。 所有的Iterable均可以通过内置函数iter()来转变为Iterator。 对迭代器来讲,有一个next()就够了。在你使用for 和 in 语句时,程序就会自动调用即将被处理的对象的迭代器对象,然后使用它的next()方法,直到监测到一个StopIteration异常。
py3study
2020/01/08
3360
Python随笔(四)、python基础
闭包和装饰器
在函数内部再定义⼀个函数,并且这个内部函数⽤到了外部的变量,这个函数以及⽤到外部函数的变量及参数叫闭包
@小森
2024/03/15
860
清清爽爽理解Python装饰器
不知不觉已经连续写了13天了,很享受每天写公众号这个过程,通过写作将自己每天学习的Python知识分享出来,但是学习的东西是零散的,需要自己通过一定的逻辑顺序将零散的知识串起来,这很锻炼自己的逻辑能力和写作能力。
stormwen
2019/08/05
3330
python高级-装饰器(19)
某公司有多个研发部⻔,1个基础平台部⻔,基础平台负责提供底层的功能,如:数据库操作、redis调⽤、监控API等功能。研发部⻔使⽤基础功能时,只需调⽤基础平台提供的功能即可。如下:
Se7eN_HOU
2019/09/11
4140
python高级-装饰器(19)
python装饰器和语法糖
装饰器在大工程中比较常见,那么如何理解装饰器呢?打个比方,假如你建好了一栋大房子,建好后还想加一些功能,这个时候房子的主体结构是不能动了,只好在现有房子的基础上做一些装饰/装修。这些装饰在不影响/不修改原来房子功能的基础上,增加了美观等功能。
烤粽子
2021/07/07
8070
装饰器进阶
装饰带参数函数 def foo(func): # 接收的参数是一个函数名 def bar(x, y): # 这里需要定义和被装饰函数相同的参数 print("这里是新功能...") # 新功能 func(x, y) # 被装饰函数名和参数都有了,就能执行被装饰函数了 return bar # 定义一个需要两个参数的函数 @foo def f1(x, y): print("{}+{}={}".format(x, y, x+y)) # 调用
新人小试
2018/04/12
6000
函数 之装饰器
  在看装饰器之前,我们先来搞清楚什么是闭包函数。python是一种面向对象的编程语言,在python中一切皆对象,这样就使得变量所拥有的属性,函数也同样拥有。这样我们就可以理解在函数内创建一个函数的行为是完全合法的。这种函数被叫做内嵌函数,这种函数只可以在外部函数的作用域内被正常调用,在外部函数的作用域之外调用会报错,例如:
全栈程序员站长
2022/07/21
4280
函数 之装饰器
深入了解Python中的装饰器
Python的装饰器是AOP编程的一种实现,其他很多语言也都支持装饰器模式。 注:AOP是指面向切面编程,详见 AOP概念
tunsuy
2022/10/27
3320
Python 函数装饰器和闭包
创建一个装饰器工厂函数,把参数传给它,返回一个装饰器,然后再把它应用到要装饰的函数上。
为为为什么
2022/08/09
6560
Python 函数装饰器和闭包
「Python」闭包与装饰器
请注意,本文编写于 1730 天前,最后修改于 999 天前,其中某些信息可能已经过时。
曼亚灿
2023/05/17
2100
python中的装饰器decorator
而我们想为这三个函数增加一个函数调用打印功能 类似print("call f1()")
py3study
2020/01/15
5520
一文读懂python装饰器由来(二)
上一篇文章主要以一步一步演进的方式介绍了装饰器的工作原理以及使用(没看的小伙伴可以关注一下 一文读懂Python装饰器由来(一)),其实只要认真学习上一篇文章,已经能够满足日常对装饰器的使用了。但是,若想真正理解装饰器,并进行更高阶的使用还要了解其他一些知识:
Python中文社区
2018/07/26
4240
python Function(函数)
函数是python为了代码最大程度地重用和最小化代码冗余而提供的基本程序结构。函数是一种设计工具,它能让程序员将复杂的系统分解为可管理的部件; 函数用于将相关功能打包并参数化。 在python中可以创建如下4种函数:     1)、全局函数:定义在模块中(直接定义在模块中的函数)。     2)、局部函数:嵌套于其它函数中(在函数中再定义的函数)。     3)、lambda函数:表达式。匿名函数(它仅是一个表达式),它可以出现在任何位置,很高的录活性。     4)、方法:与特定数据类型关联的函数,并且只能与数据类型相关一起使用。定义在类中的函数。    python也提供了很多内置函数 函数与过程的区别:     函数都有return返回值。返回一个对象 创建函数     def functionName(parameters):         suite 相关概念:     def 是一个可执行语句;因此可以出现在任何能够使用的地方,甚至可以嵌套于其它语句,例if或while中。def创建了一个对象  并将其赋值给一个变量名(即函数名);     return用于返回结果对象,其为可选项;无return语句的函数自动返回一个None对象;返回多个值时,彼此间使用逗号分隔,且组合为元组形式返回一个对象。     def语句运行之后,可以在程序中通过函数名后附加括号进行调用 。     例1:
py3study
2020/01/13
7830
相关推荐
python装饰器的学习
更多 >
LV.2
这个人很懒,什么都没有留下~
目录
  • 1、环境要求
  • 2、构建模块
    • 2.1 构建父模块spring6
    • 2.2 构建子模块spring-first
  • 3、程序开发
    • 3.1 引入依赖
    • 3.2 创建java类
    • 3.3 创建配置文件
    •  3.4 创建测试类测试
    • 3.5 运行测试程序
  • 4、程序分析
  • 5、启用Log4j2日志框架
    • 5.1 Log4j2日志概述
    • 5.2 引入Log4j2依赖
    • 5.3 加入日志配置文件
    • 5.4 测试
    • 5.5 使用日志
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档