SSH学习笔记(9)__Spring5_概述/简单程序/整合日志
Spring5学习笔记
本文章基于B站UP主 孙帅suns 的视频教程《孙哥说Spring5》进行整理记录,本文章仅用于个人学习/交流使用。
参考博客:https://blog.csdn.net/weixin_43734095/article/details/106309373
目录标题
- Spring5学习笔记
- 一.spring的概述
- 1.1 引言
- 1.2 什么是 Spring?
- 1.什么是轻量级
- 2.JavaEE 的解决方案
- 3.整合设计模式
- 4.什么是设计模式
- 1.3 工厂设计模式
- 1.什么是工厂设计模式?
- 2.传统的实现方式
- 3.简单的工厂设计//反射工厂
- 4.通用的工厂设计
- 5.通用工厂的使用方法
- 6.总结:
- 二.第一个spring程序
- 2.1 环境搭建
- 1.软件版本
- 2.spring的jar包
- 3.Spring 的配置文件:
- 4.在idea中建立spring配置文件
- 2.2 Spring 的核心API
- 1.ApplicationContext
- 2.3 程序开发
- 2.4 细节分析
- 1.名词解释:
- 2.Spring 工厂的相关的方法
- 3.配置文件中的细节
- 2.5 Spring工厂的底层实现原理
- 2.6 思考问题
- 三.Spring5.x 与 日志框架 的整合
- 3.1 spring如何整合日志框架
- 3.2 Spring 如何整合⽇志框架?
一.spring的概述
本文章基于B站UP视频教程《孙哥说Spring5(2020版) 》
1.1 引言
在spring出现之前,使用的较多的是EJB,但存在着一些问题
1.2 什么是 Spring?
Spring是⼀个轻量级的 JavaEE 解决⽅案,整合众多优秀的设计模式。
1.什么是轻量级
1.对于运⾏环境是没有额外要求的;
适用开源:tomcat、resion、jetty
适用收费:weblogic、websphere
2.代码移植性⾼:不需要实现额外接⼝。
2.JavaEE 的解决方案
3.整合设计模式
⼯⼚,代理,模板,策略模式
4.什么是设计模式
⼴义概念:⾯向对象设计中,解决特定问题的经典代码。
狭义概念:GOF4⼈帮定义的23种设计模式:⼯⼚、适配器、装饰器、⻔⾯、代理、模板…
1.3 工厂设计模式
1.什么是工厂设计模式?
概念:通过工厂类,创建对象;
好处:解耦合。
耦合:指定是代码间的强关联关系,⼀⽅的改变会影响到另⼀⽅;
耦合存在的问题:不利于代码维护;
简单:把接⼝的实现类,硬编码在程序中;
2.传统的实现方式
User user = new User();
UserDAO userDAO = new UserDAOImpl();
3.简单的工厂设计//反射工厂
1.使用工厂设计模式
2.使用properties配置文件
- 工厂类:BeanFactor.java
package com.baizhiedu.basic;import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;public class BeanFactory {//1.加载配置文件,从配置文件中获取private static Properties env = new Properties();static{try {//第一步 获得IO输入流InputStream inputStream = BeanFactory.class.getResourceAsStream("/applicationContext.properties");//第二步 文件内容 封装 Properties//集合中 key = userService value = com.baizhixx.UserServiceImplenv.load(inputStream);inputStream.close();} catch (IOException e) {e.printStackTrace();}}/*对象的创建方式:1. 直接调用构造方法 创建对象 UserService userService = new UserServiceImpl();2. 通过反射的形式 创建对象 解耦合Class clazz = Class.forName("com.baizhiedu.basic.UserServiceImpl");UserService userService = (UserService)clazz.newInstance();*///2.解决UserService耦合public static UserService getUserService() {UserService userService = null;try {//com.baizhiedu.basic.UserServiceImplClass clazz = Class.forName(env.getProperty("userService"));userService = (UserService) clazz.newInstance();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (InstantiationException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();}return userService;}}
- 配置文件: applicationContext.properties
# Properties 集合 存储 Properties文件的内容
# 特殊Map key=String value=String
# 使用:
# Properties [userService = com.baizhiedu.xxx.UserServiceImpl]
# Properties.getProperty("userService")userService = com.baizhiedu.basic.UserServiceImpl
- 测试类
@Testpublic void test1() {//UserServcice userService = new UserServiceImplNew()//UserService userService = new UserServiceImpl();UserService userService = (UserService) BeanFactory.getBean("userService");userService.login("name", "suns");User user = new User("suns", "123456");userService.register(user);}
4.通用的工厂设计
问题:简单⼯⼚会存在⼤量的代码冗余。
package com.baizhiedu.basic;import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;public class BeanFactory {private static Properties env = new Properties();static{try {InputStream inputStream=BeanFactory.class.getResourceAsStream("/applicationContext.properties");env.load(inputStream);inputStream.close();} catch (IOException e) {e.printStackTrace();}}/*key 小配置文件中的key [userDAO,userService]*/public static Object getBean(String key){Object ret = null;try {Class clazz = Class.forName(env.getProperty(key));ret = clazz.newInstance();} catch (Exception e) {e.printStackTrace();}return ret;}
}
使用: getBean()方法,强制类型转换
UserService userService = (UserService) BeanFactory.getBean("userService");
5.通用工厂的使用方法
1.定义类型 (类)
2.通过配置⽂件的配置告知⼯⼚
applicationContext.properties
中 key = value;
3.通过⼯⼚获得类的对象
Object ret = BeanFactory.getBean("key");
6.总结:
Spring本质:⼯⼚
系统提供:ApplicationContext (applicationContext.xml)
二.第一个spring程序
2.1 环境搭建
1.软件版本
JDK1.8+
Maven3.5+
IDEA2018+
Spr ingFramework 5.1 .4
官方网站www. spring.io
2.spring的jar包
依赖查询网站:https://mvnrepository.com/;
配置 Spring 的 jar 包:在pom.xml 文件中
<!--设置pom文件-->
<!--https://mvnrepository.com/artifact/org.springframework/spring-context -->
<dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.1.4.RELEASE</version>
</dependency>
3.Spring 的配置文件:
配置⽂件的放置位置:任意位置,没有硬性要求;
配置⽂件的命名 :没有硬性要求,建议:applicationContext.xml;
⽇后应⽤ Spring 框架时,需要进⾏配置⽂件路径的设置。
4.在idea中建立spring配置文件
一般在 main-resources目录下
2.2 Spring 的核心API
1.ApplicationContext
作⽤:Spring 提供的 ApplicationContext 这个⼯⼚,⽤于对象的创建;
好处:解耦合
1.ApplicationContext 是接⼝类型;
接⼝:屏蔽实现的差异
⾮web环境 (main junit) :ClassPathXmlApplicationContext
web环境 :XmlWebApplicationContext
2.重量级资源:
ApplicationContext ⼯⼚的对象占⽤⼤量内存。
不会频繁的创建对象 ,⼀个应⽤只会创建⼀个⼯⼚对象。
ApplicationContext ⼯⼚:⼀定是线程安全的(多线程并发访问)。
2.3 程序开发
1.创建类型:Person.java
public class Person {}
2.配置文件的配置:applicationContext. 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"><bean id="person" class="com.yusael.basic.Person"/></beans>
3.通过工厂类,获得对象
/*** 用于测试Spring的第一个程序*/
@Test
public void test() {// 1、获取spring的工厂ApplicationContext ctx = new ClassPathXmlApplicationContext("/applicationContext.xml");// 2、通过工厂类获得对象Person person = (Person)ctx.getBean("person");System.out.println(person);
}
2.4 细节分析
1.名词解释:
Spring 工厂创建的对象,叫做 bean 或者 组件(componet);
2.Spring 工厂的相关的方法
1.getBean
:(重载)传入 id值 和 类名 获取对象,不需要强制类型转换。
// 通过这种⽅式获得对象,就不需要强制类型转换
Person person = ctx.getBean("person", Person.class);
System.out.println("person = " + person);
2.getBean
:(重载)只指定类名,Spring 的配置文件中只能有一个 bean 是这个类型。
// 使用这种方式的话, 当前Spring的配置文件中 只能有一个bean class是Person类型
Person person = ctx.getBean(Person.class);
System.out.println("person = " + person);
3.getBeanDefinitionNames
:获取 Spring 配置文件中所有的 bean 标签的 id 值。
// 获取的是Spring工厂配置文件中所有bean标签的id值 person person1
String[] beanDefinitionNames = ctx.getBeanDefinitionNames();
for (String beanDefinitionName : beanDefinitionNames) {System.out.println("beanDefinitionName = " + beanDefinitionName);
}
4.getBeanNamesForType
:根据类型获得 Spring 配置文件中对应的 id 值。
// 根据类型获得Spring配置文件中对应的id值
String[] beanNamesForType = ctx.getBeanNamesForType(Person.class);
for (String id : beanNamesForType) {System.out.println("id = " + id);
}
5.containsBeanDefinition
:用于判断是否存在指定 id 值的 bean,不能判断 name 值。
// 用于判断是否存在指定id值的bean,不能判断name值
if (ctx.containsBeanDefinition("person")) {System.out.println(true);
} else {System.out.println(false);
}
6.containsBean
:用于判断是否存在指定 id 值的 bean,也可以判断 name 值。
// 用于判断是否存在指定id值的bean,也可以判断name值
if (ctx.containsBean("p")) {System.out.println(true);
} else {System.out.println(false);
}
3.配置文件中的细节
1.如果 bean 只配置 class 属性:
<bean class="com.yusael.basic.Person"></bean>
会自动生成一个 id,com.yusael.basic.Person#0
可以使用 getBeanNamesForType 验证。
应⽤场景:
如果这个 bean 只需要使⽤⼀次,那么就可以省略 id 值;
如果这个 bean 会使⽤多次,或者被其他 bean 引⽤则需要设置 id 值;
2.name 属性:
作⽤:⽤于在 Spring 的配置⽂件中,为 bean 对象定义别名
<bean id="person" name="p" class="com.yusael.basic.Person"></bean>Person p=(Person)ctx.getBean("p");
name 与 id 的相同点:
ctx.getBean(“id”) 或 ctx.getBean(“name”) 都可以创建对象;、
<bean id=“person” class=“Person”/> 与 <bean name=“person” class=“Person”/> 等效;
name 与 id 的区别:
别名可以定义多个,但是 id 属性只能有⼀个值;
XML 的 id 属性的值,命名要求:必须以字⺟开头,可以包含 字⺟、数字、下划线、连字符;不能以特殊字符开头 /person;
XML 的 name 属性的值,命名没有要求,/person 可以。
但其实 XML 发展到了今天:ID属性的限制已经不存在,/person也可以。
containsBeanDefinition,可以判断id值,不能判断name值
containsBean,可以判断id值,可以判断name值
2.5 Spring工厂的底层实现原理
简易版
Spring工厂是可以调用对象的私有方法来创建对象的
2.6 思考问题
问题:未来在开发过程中,是不是所有的对象,都会交给 Spring ⼯⼚来创建呢?
回答:理论上是的,但是有特例 :实体对象(entity) 是不会交给Spring创建,它由持久层框架进⾏创建。
三.Spring5.x 与 日志框架 的整合
Spring 与⽇志框架进⾏整合,⽇志框架就可以在控制台中,输出Spring框架运⾏过程中的⼀些重要的信息。
好处:便于了解Spring框架的运⾏过程,利于程序的调试。
3.1 spring如何整合日志框架
默认日志框架
Spring 1.x、2.x、3.x 早期都是基于commonslogging.jar
Spring 5.x 默认整合的⽇志框架 logback、log4j2
3.2 Spring 如何整合⽇志框架?
Spring5.x 整合 log4j:
引⼊ log4j.jar 包:在pom文件中
<dependency><groupId>org.slf4j</groupId><artifactId>slf4j-log4j12</artifactId><version>1.7.21</version>
</dependency>
<dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version>
</dependency>
引⼊ log4.properties 配置⽂件:在resources目录下
# resources文件夹根目录下### 配置根log4j.rootLogger = debug,console### 日志输出到控制台显示log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.Target=System.out
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
SSH学习笔记(9)__Spring5_概述/简单程序/整合日志相关推荐
- C++下opencv学习笔记(一)(图像的简单读取丶显示与存储)
C++下opencv学习笔记(一)(图像的简单读取丶显示与存储) 前言 学习C++ OpenCV,第一需要具备面向对象语言的基础,第二要对图像处理机器学习有基础了解,容易入门.觉得自己基础已经有了可以 ...
- oracle学习笔记 Oracle体系结构概述
oracle学习笔记 Oracle体系结构概述 从这节开始,开始讲oracle数据库体系结构. 首先从总体上,从概述上把oracle整体的体系结构讲一下, 然后接下来的时间我们会一块一块的将oracl ...
- RN学习笔记01:概述、特点与环境搭建
RN学习笔记01:概述.特点与环境搭建 一.RN概述 React Native(简称RN)是Facebook于2015年4月开源的跨平台移动应用开发框架,是Facebook早先开源的JS框架 Reac ...
- 知识图谱·概念与技术--第1章学习笔记--知识图谱概述--知识图谱的概念,与传统语义网络的区别
知识图谱·概念与技术--第1章学习笔记--知识图谱概述--知识图谱的概念,与传统语义网络的区别 知识图谱的概念,与传统语义网络的区别 狭义概念 作为语义网络的内涵 与传统语义网络的区别 优点 缺点 与 ...
- Spark学习笔记1——第一个Spark程序:单词数统计
Spark学习笔记1--第一个Spark程序:单词数统计 笔记摘抄自 [美] Holden Karau 等著的<Spark快速大数据分析> 添加依赖 通过 Maven 添加 Spark-c ...
- TI CC1101学习笔记:工作原理简单入门
众所周知,在IOT的市场应用中,从通信协议细分的话,有SUB-1G,2.4G,3G, 4G,以及最新推出的5G,虽然5G通信协议已经在崭露头角,但是不同的通信协议在不同的应用领域之中还是占据着一定的重 ...
- Java学习笔记-Day42 HTML概述
Java学习笔记-Day42 HTML概述 一.前端简介 二.HTML 语言 1.简介 2.HTML的编写规范 3.HTML标签的声明 4.HTML的调试 5.标记语言的特点 6.头标签head 7. ...
- 华为HCIA-datacom 学习笔记14——WLAN概述
华为HCIA-datacom 学习笔记14--WLAN概述 1.WLAN(无线局域网) 通过无线技术构造的无线局域网络.WLAN广义上是指以无线电波.激光.红外线等无线信号代替有线局域网中的部分或全部 ...
- tensorflow学习笔记二——建立一个简单的神经网络拟合二次函数
tensorflow学习笔记二--建立一个简单的神经网络 2016-09-23 16:04 2973人阅读 评论(2) 收藏 举报 分类: tensorflow(4) 目录(?)[+] 本笔记目的 ...
最新文章
- 无需人脸检测,实时6自由度3维人脸姿态估计img2pose
- python基础:try...except...的详细用法
- 《Head First Python》第四章--持久存储
- 如何 Credit Hold 客户
- Codeforces Round #459 (Div. 2)题解
- 附录:保护模式下的各个“对象”
- c语言求栈长度程序,数据结构C语言实现之顺序栈
- Android UI美化——颜色
- word文档转换为md文档
- 【《Real-Time Rendering 3rd》 提炼总结】(八) 第九章 · 全局光照:光线追踪、路径追踪与GI技术进化编年史
- 计161--Problem H: 求三角形面积-gyy
- pbr发光 unity_Unity PBR—BRDF
- 嵌入式Linux开发常用命令总结
- Word如何交叉引用以及交叉引用参考文献后使用逗号分隔
- 【Logback】<appender>标签详解
- BUUCTF:派大星的烦恼
- cocos2dx-js 开发
- 2021-2027全球与中国冰箱稳定器市场现状及未来发展趋势
- windows 利用R定时抓取猫眼专业版电影票房
- 微软NewBing的申请和实测体验