网站建设补贴,网站建设中 html5,多备份 wordpress,网络规划与设计实训报告了解准备
什么是Spring#xff1f; Spring是一款轻量级的控制反转#xff08;IOC#xff09;和面向切面编程#xff08;AOP#xff09;的非入侵式开源框架 2002年Spring的前身interface21发布#xff0c;随后在2004年3月24日正式更名发布Spring1.0版本Spring Frameword缔…了解准备
什么是Spring Spring是一款轻量级的控制反转IOC和面向切面编程AOP的非入侵式开源框架 2002年Spring的前身interface21发布随后在2004年3月24日正式更名发布Spring1.0版本Spring Frameword缔造者 Rod Johnson悉尼大学音乐学博士生
Spring框架主要由七部分组成分别是 Spring Core、 Spring AOP、 Spring ORM、 Spring DAO、Spring Context、 Spring Web和 Spring Web MVC Spring三大核心IOC控制反转、DI依赖注入、AOP面向切面编程
Spring整合了现有的技术框架使这些技术更加易于使用
Spring官网https://spring.io/ 下载地址https://repo.spring.io/ui/native/release/org/springframework/spring GitHub地址https://github.com/spring-projects/spring-framework maven依赖
!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc --
dependencygroupIdorg.springframework/groupIdartifactIdspring-webmvc/artifactIdversion5.3.18/version
/dependency整合MyBatis时导入
!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc --
dependencygroupIdorg.springframework/groupIdartifactIdspring-jdbc/artifactIdversion5.3.23/version
/dependencyIOC思想
引入IOC
准备Dao层接口和一堆实现类
public interface UserDao {void getUser();
}
public class UserDaoImpl implements UserDao{public void getUser() {System.out.println(UserDao获取User成功);}
}
public class UserDaoMySqlImpl implements UserDao{public void getUser() {System.out.println(UserDaoMySqlImpl获取User成功);}
}
public class UserDaoOracleImpl implements UserDao{public void getUser() {System.out.println(UserDaoOracleImpl获取User成功);}
}准备业务层
public interface UserService {void getUser();
}
public class UserServiceImpl implements UserService{private UserDao userDao new UserDaoImpl;public void getUser() {userDao.getUser();}
}测试不同UserDao实现类的getUser方法
public class MyTest {Testpublic void testGetUser(){UserServiceImpl service new UserServiceImpl();service.getUser();}
}可以发现当需要调用不同UserDao实现类时每次都需要区service中修改UserDao实例的指向
private UserDao userDao new UserDaoImpl;
private UserDao userDao new UserDaoOracleImpl;
private UserDao userDao new UserDaoMySqlImpl;这样设计的耦合性极高对程序执行的控制权始终在开发人员手中当用户提出不同需求就需要我们不断去修改UserDao实例的指向。如果代码数量大那么需要修改的就不止一处下面在service中注入set方法来动态的获取不同的UserDao实例指向
service
public class UserServiceImpl implements UserService{private UserDao userDao;// 注入set方法 解耦public void setUserDao(UserDao userDao){this.userDao userDao;}public void getUser() {userDao.getUser();}
}Test
public class MyTest {Testpublic void testGetUser(){UserServiceImpl service new UserServiceImpl();service.setUserDao(new UserDaoOracleImpl());service.getUser();}
}上述示例就可以动态的去选择执行用户指定的方法。此处的Test可以看作是一个servlet它获取到用户的请求之后解析出对应执行的方法再通过service去调用执行耦合性就降低许多即用户需求和程序之间的耦合性降低程序执行的控制权交给用户。以此完成控制反转IOC
IOC本质
IOC的本质就是一种控制反转的设计思想它不完全等同于DIDI(依赖注入)可以理解为实现IOC的一种方式。
那我的理解其实是不能说控制权交给了用户只是我们通过程序编写可以实现对用户需求的解析。解析出用户的需求对应程序中所要执行的方法即可。不能理解为控制权只能说用户具有了主动权并且在代码层面我们提高了程序的动态特性。
所谓控制反转就是说获取对象的不再由程序的硬编码决定而是反转到了用户手中。首先程序会解析出用户需求再动态的获取相应对象
XML配置Spring
以上述UserDao示例配置
?xml version1.0 encodingUTF-8?
beans xmlnshttp://www.springframework.org/schema/beansxmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd!-- 将每一个UserDao的实现类映射到Spring容器中的bean --bean idmysqlImpl classcom.mountain.dao.MySqlImpl/bean idoracleImpl classcom.mountain.dao.OracleImpl/bean iduserService classcom.mountain.service.UserServiceImplproperty nameuserDao refmysqlImpl//bean
/beans测试
Test
public void testGetUser(){// 获取spring上下文对象ApplicationContext context new ClassPathXmlApplicationContext(application-context.xml);UserServiceImpl service (UserServiceImpl) context.getBean(userService);System.out.println(service.getUser());
}可以看到创建对象不需要再利用new关键字硬编码而是完全交给Spring容器进行创建我们在xml配置中将每一个UserDao的实现类映射到Bean最后测试利用Spring上下文对象来获取映射好的bean实例
配置细节
property标签name对应类中的字段value是可以自定义的具体值ref则是将该字段映射到具体某一个类上比如引用数据类型就会用到ref配置bean中的id要与最终用Spring上下文对象getBean获取实例时的参数一致
IOC体现
对象的创建、管理全部交给Spring容器。主动权交给Spring程序不在主动的创建对象而是被动的接收对象利用set方法注入
IOC创建对象方式
默认创建对象方式
// 无参构造
public User() {System.out.println(默认使用无参构造);
}
// 测试
ApplicationContext context new ClassPathXmlApplicationContext(application-Context.xml);
User user (User) context.getBean(User);最终打印默认使用无参构造所以在不进行任何其他配置的情况下Spring默认创建bean依然走无参构造器
public User(String name) {}
bean idUser classcom.yuqu.pojo.Userproperty namename value情人节/
/bean如果我们只显式了有参构造那么无参构造被覆盖之后将会导致application-Context.xml文件配置的bean编译直接报错
使用含参构造时 方式一
!-- 方式一index代表构造器参数索引 --
bean idUser classcom.yuqu.pojo.Userconstructor-arg index0 value情人节/
/bean方式二
!-- 方式二type代表参数类型 基本数据类型用 弊端较大 --
bean idUser classcom.yuqu.pojo.Userconstructor-arg typejava.lang.String value圣诞节/
/bean但是假设多个参数都是java.lang.String那么方式二就是不可取的
方式三
!-- 方式三直接通过参数名设置 --
bean idUser classcom.yuqu.pojo.Userconstructor-arg namename value国庆节/
/bean