当前位置: 首页 > news >正文

《Spring日志整合与注入技术:从入门到精通》

1.Spring与日志框架的整合

1.Spring与日志框架进行整合,日志框架就可以在控制台中,输出Spring框架运行过程中的一些重要的信息。

好处:方便了解Spring框架的运行过程,利于程序的调试。

  •  Spring如何整合日志框架

Spring5.x整合log4j

1.引入log4j.jar包

2.引入log4j.properties配置文件

  •  pom文件
<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.25</version>
</dependency>
  •  log4j.properties
### 设置###
log4j.rootLogger = debug,stdout

### 输出信息到控制抬 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n

2.注入(Injection)

1.什么是注入

通过Spring工厂及配置文件,为所创建对象的成员变量赋值

 1.1为什么需要注入?

 1.2如何进行注入[开发步骤]

  • 类的成员变量提供 set get方法
  • 配置spring的配置文件
 <bean id="person" class="basic.Person">
        <property name="name">
            <value>张三</value>
        </property>
        <property name="age">
            <value>18</value>
        </property>
    </bean>

1.3注入好处

解耦合

2.Spring注入的原理分析(简易版) 

Spring解析到<property name=""><value> <property等效于调用该对象的set方法。

Spring通过底层调用对象属性对应的set方法,完成成员变量的赋值,这种方式也称之为set注入。

3.Set注入详解

针对不同类型的成员变量,在<property>标签需要嵌套其他标签

 1.JDK内置类型

1.1Spring内置8中基本类型

<value>张三<value>

1.2数组

<property name="emails">
            <list>
                <value>888888888@qq.com</value>
                <value>6666666666@qq.com</value>
            </list>
        </property>

1.3Set集合

<property name="phones">
            <set>
                <value>123456789</value>
                <value>987654321</value>
                <value>987654321</value>
            </set>
        </property>

1.4List集合

<property name="address">
            <list>
                <value>北京</value>
                <value>上海</value>
            </list>
        </property>

1.5Map集合

注意:map---entry--key有特定的标签<key></key>
值根据对应类型选择对应类型的标签
<property name="qqs">
            <map>
                <entry key="qq" value="123456789"/>
                <entry key="wechat" value="123456789"/>
            </map>
</property>

1.6Properties

Properties类型 特殊的Map key=String value=String

<property name="properties">
            <props>
                <prop key="wechat">12345678</prop>
                <prop key="qq">12345678</prop>
            </props>
        </property>

2.用户自定义类型

为成员标量提供set get方法

配置文件中进行注入(赋值)

2.1第一种方式

 <bean id="userService" class="basic.UserServiceImpl">
        <property name="userDao">
            <bean id="userDao" class="basic.UserDaoImpl"></bean>
        </property>
    </bean>

2.2第二种方式

  • 第一种方式存在的问题

1.配置文件代码冗余

2.被注入的对象(userDao),多次创建,浪费(JVM)内存资源

  •  为成员变量提供set get方法
  • 配置文件中进行配置
<bean id="userDao" class="basic.UserDaoImpl"></bean>
    <bean id="userService" class="basic.UserServiceImpl">
        <property name="userDao" ref="userDao"></property>
    </bean>

4.Set注入简化写法

4.1基于属性简化

JDK类型注入

<property name="name" value="张三"></property>

注意:value属性 只能简化 8种基本数据类型+String 注入标签

用户自定义标签

<bean id="userService" class="basic.UserServiceImpl">
    <property name="userDao" ref="userDao"></property>
</bean>

4.2基于p命名空间简化

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

<bean id="userDao" class="basic.UserDaoImpl"></bean>
<bean id="userService" class="basic.UserServiceImpl" p:userDao-ref="userDao"></bean>

5.构造注入 

注入:通过Spring的配置文件,为成员变量赋值

Set注入:Spring调用Set方法,通过配置文件为成员变量赋值

构造注入:Spring调用构造方法,通过配置文件,为成员变量赋值

 1.开发步骤

  •  提供有参的构造方法
 private String name;
    private int age;
    public Customer(String name, int age) {
        this.name = name;
        this.age = age;
    }
  • Spring的配置文件
<bean id="customer" class="basic.Customer">
            <constructor-arg>
                <value>张三</value>
            </constructor-arg>
            <constructor-arg>
                <value>18</value>
            </constructor-arg>
        </bean>

参数位置对应 并且一个参数对应一个constructor-arg标签

2.构造方法的重载

2.1参数个数不同时

通过控制<constructor-arg>标签的数量进行区分

2.2参数个数相同时

<bean id="customer" class="basic.Customer">
    <constructor-arg type="int">//指定类型
        <value>18</value>
    </constructor-arg>
</bean>

 6.总结

未来实战中,应用set注入还是构造注入?

set注入更到:

1.构造注入麻烦(重载)

2.Spring框架底层 大量应用set注入!

相关文章:

  • 物理服务器抵御网络攻击的方法都有哪些?
  • SCSS详解
  • 创建模式-工厂方法模式(Factory Method Pattern)
  • UE5以插件的形式加载第三方库
  • AI+视频监控电力巡检:EasyCVR视频中台方案如何赋能电力行业智能化转型
  • 爬虫的精准识别:基于 User-Agent 的正则实现
  • 【RTSP】客户端(一):RTSP协议实现
  • 【机械视觉】C#+VisionPro联合编程———【五、硬币检测小项目实现(C#+VisionPro联合编程和csv文件格式操作)】
  • [Web]ServletContext域(Application)
  • 【Agent】Windows 和 CentOS 安装 Conda
  • wireguard搭配udp2raw部署内网
  • 坐落于杭州的电商代运营公司品融电商
  • 智能验证码破解:突破reCAPTCHA、Cloudflare和hCaptcha的全方位解决方案
  • selenium的鼠标操作
  • 每天一道算法题【蓝桥杯】【x的平方根】
  • 通义万相2.1 图生视频:为AI绘梦插上翅膀,开启ALGC算力领域新纪元
  • Qt5.10版本以下 qml ui语言动态切换
  • MySQL EXPLAIN 详解
  • 网络安全linux命令
  • CAAC无人机考证备考清单
  • 国际乒联主席索林:洛杉矶奥运会增设混团是里程碑事件
  • 东部沿海大省浙江,为何盯上内河航运?
  • 上海一保租房社区亮相,首批546套房源可拎包入住
  • 就规范涉企行政执法专项行动有关问题,司法部发布解答
  • 既是工具又是食物,可食用机器人开启舌尖上的新科技
  • 政企共同发力:多地密集部署外贸企业抢抓90天政策窗口期