Version | Feature |
---|---|
Spring 2.5 | 发布于 2007 年。这是第一个支持注解的版本。 |
Spring 3.0 | 发布于 2009 年。它彻底利用了 Java5 中的改进,并为 JEE6 提供了支持。 |
Spring 4.0 | 发布于 2013 年。这是第一个彻底支持 JAVA8 的版本。 |
Spring 配置文件是 XML 文件。该文件主要包含类信息。它描述了这些类是如何配置以及相互引入的。可是,XML 配置文件冗长且更加干净。若是没有正确规划和编写,那么在大项目中管理变得很是困难。javascript
Spring 应用通常有如下组件:前端
使用 Spring 有如下方式:java
Spring 框架的核心是 Spring 容器。容器建立对象,将它们装配在一块儿,配置它们并管理它们的完整生命周期。Spring 容器使用依赖注入来管理组成应用程序的组件。容器经过读取提供的配置元数据来接收对象进行实例化,配置和组装的指令。该元数据能够经过 XML,Java 注解或 Java 代码提供。git
在依赖注入中,您没必要建立对象,但必须描述如何建立它们。您不是直接在代码中将组件和服务链接在一块儿,而是描述配置文件中哪些组件须要哪些服务。由 IoC 容器将它们装配在一块儿。github
一般,依赖注入能够经过三种方式完成,即:web
在 Spring Framework 中,仅使用构造函数和 setter 注入。正则表达式
构造函数注入 | setter 注入 |
---|---|
没有部分注入 | 有部分注入 |
不会覆盖 setter 属性 | 会覆盖 setter 属性 |
任意修改都会建立一个新实例 | 任意修改不会建立一个新实例 |
适用于设置不少属性 | 适用于设置少许属性 |
BeanFactory | ApplicationContext |
---|---|
它使用懒加载 | 它使用即时加载 |
它使用语法显式提供资源对象 | 它本身建立和管理资源对象 |
不支持国际化 | 支持国际化 |
不支持基于依赖的注解 | 支持基于依赖的注解 |
IoC 的一些好处是:spring
Spring 中的 IoC 的实现原理就是工厂模式加反射机制。数据库
示例:编程
interface Fruit {
public abstract void eat();
}
class Apple implements Fruit {
public void eat(){
System.out.println("Apple");
}
}
class Orange implements Fruit {
public void eat(){
System.out.println("Orange");
}
}
class Factory {
public static Fruit getInstance(String ClassName) {
Fruit f=null;
try {
f=(Fruit)Class.forName(ClassName).newInstance();
} catch (Exception e) {
e.printStackTrace();
}
return f;
}
}
class Client {
public static void main(String[] a) {
Fruit f=Factory.getInstance("io.github.dunwu.spring.Apple");
if(f!=null){
f.eat();
}
}
}
bean 所需的依赖项和服务在 XML 格式的配置文件中指定。这些配置文件一般包含许多 bean 定义和特定于应用程序的配置选项。它们一般以 bean 标签开头。例如:
<bean id="studentbean" class="org.edureka.firstSpring.StudentBean">
<property name="name" value="Edureka"></property>
</bean>
您能够经过在相关的类,方法或字段声明上使用注解,将 bean 配置为组件类自己,而不是使用 XML 来描述 bean 装配。默认状况下,Spring 容器中未打开注解装配。所以,您须要在使用它以前在 Spring 配置文件中启用它。例如:
<beans>
<context:annotation-config/>
<!-- bean definitions go here -->
</beans>
Spring 的 Java 配置是经过使用 @Bean 和 @Configuration 来实现。
例如:
@Configuration
public class StudentConfig {
@Bean
public StudentBean myStudent() {
return new StudentBean();
}
}
Spring bean 支持 5 种 scope:
仅当用户使用支持 Web 的 ApplicationContext 时,最后三个才可用。
spring bean 容器的生命周期流程以下:
<bean>
的 init-method 属性),那么将调用它。<bean>
的 destroy-method 属性),那么将调用它。只有将 bean 用做另外一个 bean 的属性时,才能将 bean 声明为内部 bean。为了定义 bean,Spring 的基于 XML 的配置元数据在 <property>
或 <constructor-arg>
中提供了 <bean>
元素的使用。内部 bean 老是匿名的,它们老是做为原型。
例如,假设咱们有一个 Student 类,其中引用了 Person 类。这里咱们将只建立一个 Person 类实例并在 Student 中使用它。
Student.java
public class Student {
private Person person;
//Setters and Getters
}
public class Person {
private String name;
private String address;
//Setters and Getters
}
bean.xml
<bean id=“StudentBean" class="com.edureka.Student">
<property name="person">
<!--This is inner bean -->
<bean class="com.edureka.Person">
<property name="name" value=“Scott"></property>
<property name="address" value=“Bangalore"></property>
</bean>
</property>
</bean>
当 bean 在 Spring 容器中组合在一块儿时,它被称为装配或 bean 装配。 Spring 容器须要知道须要什么 bean 以及容器应该如何使用依赖注入来将 bean 绑定在一块儿,同时装配 bean。
Spring 容器可以自动装配 bean。也就是说,能够经过检查 BeanFactory 的内容让 Spring 自动解析 bean 的协做者。
自动装配的不一样模式:
<constructor-arg>
和 <property>
设置指定依赖项,这将覆盖自动装配。默认状况下,Spring 容器中未打开注解装配。所以,要使用基于注解装配,咱们必须经过配置<context:annotation-config />
元素在 Spring 配置文件中启用它。
@Required 应用于 bean 属性 setter 方法。此注解仅指示必须在配置时使用 bean 定义中的显式属性值或使用自动装配填充受影响的 bean 属性。若是还没有填充受影响的 bean 属性,则容器将抛出 BeanInitializationException。
示例:
public class Employee {
private String name;
@Required
public void setName(String name){
this.name=name;
}
public string getName(){
return name;
}
}
@Autowired 能够更准确地控制应该在何处以及如何进行自动装配。此注解用于在 setter 方法,构造函数,具备任意名称或多个参数的属性或方法上自动装配 bean。默认状况下,它是类型驱动的注入。
public class Employee {
private String name;
@Autowired
public void setName(String name) {
this.name=name;
}
public string getName(){
return name;
}
}
当您建立多个相同类型的 bean 并但愿仅使用属性装配其中一个 bean 时,您可使用@Qualifier 注解和 @Autowired 经过指定应该装配哪一个确切的 bean 来消除歧义。
例如,这里咱们分别有两个类,Employee 和 EmpAccount。在 EmpAccount 中,使用@Qualifier 指定了必须装配 id 为 emp1 的 bean。
Employee.java
public class Employee {
private String name;
@Autowired
public void setName(String name) {
this.name=name;
}
public string getName() {
return name;
}
}
EmpAccount.java
public class EmpAccount {
private Employee emp;
@Autowired
@Qualifier(emp1)
public void showName() {
System.out.println(“Employee name : ”+emp.getName);
}
}
@RequestMapping 注解用于将特定 HTTP 请求方法映射到将处理相应请求的控制器中的特定类/方法。此注解可应用于两个级别:
Spring DAO 使得 JDBC,Hibernate 或 JDO 这样的数据访问技术更容易以一种统一的方式工做。这使得用户容易在持久性技术之间切换。它还容许您在编写代码时,无需考虑捕获每种技术不一样的异常。
咱们能够经过两种方式使用 Spring 访问 Hibernate:
Spring 支持两种类型的事务管理:
AOP(Aspect-Oriented Programming), 即 面向切面编程, 它与 OOP( Object-Oriented Programming, 面向对象编程) 相辅相成, 提供了与 OOP 不一样的抽象软件结构的视角. 在 OOP 中, 咱们以类(class)做为咱们的基本单元, 而 AOP 中的基本单元是 Aspect(切面)
特定 JoinPoint 处的 Aspect 所采起的动做称为 Advice。Spring AOP 使用一个 Advice 做为拦截器,在 JoinPoint “周围”维护一系列的拦截器。
concern 是咱们想要在应用程序的特定模块中定义的行为。它能够定义为咱们想要实现的功能。
cross-cutting concern 是一个适用于整个应用的行为,这会影响整个应用程序。例如,日志记录,安全性和数据传输是应用程序几乎每一个模块都须要关注的问题,所以它们是跨领域的问题。
实现 AOP 的技术,主要分为两大类:
Spring AOP 基于动态代理方式实现;AspectJ 基于静态代理方式实现。 Spring AOP 仅支持方法级别的 PointCut;提供了彻底的 AOP 支持,它还支持属性级别的 PointCut。
将 Advice 应用于目标对象后建立的对象称为代理。在客户端对象的状况下,目标对象和代理对象是相同的。
Advice + Target Object = Proxy
为了建立一个 advice 对象而连接一个 aspect 和其它应用类型或对象,称为编织(Weaving)。在 Spring AOP 中,编织在运行时执行。请参考下图:
Spring Web MVC 框架提供 模型-视图-控制器 架构和随时可用的组件,用于开发灵活且松散耦合的 Web 应用程序。 MVC 模式有助于分离应用程序的不一样方面,如输入逻辑,业务逻辑和 UI 逻辑,同时在全部这些元素之间提供松散耦合。
DispatcherServlet 的工做流程能够用一幅图来讲明:
DispatcherServlet
捕获。DispatcherServlet
根据 -servlet.xml 中的配置对请求的 URL 进行解析,获得请求资源标识符(URI)。而后根据该 URI,调用 HandlerMapping
得到该 Handler 配置的全部相关的对象(包括 Handler 对象以及 Handler 对象对应的拦截器),最后以HandlerExecutionChain
对象的形式返回。DispatcherServlet
根据得到的Handler
,选择一个合适的 HandlerAdapter
。(附注:若是成功得到HandlerAdapter
后,此时将开始执行拦截器的 preHandler(...)方法)。Request
中的模型数据,填充Handler
入参,开始执行Handler
(Controller
)。 在填充Handler
的入参过程当中,根据你的配置,Spring 将帮你作一些额外的工做:Handler(Controller)执行完成后,向 DispatcherServlet
返回一个 ModelAndView
对象;
String
转换成Integer
、Double
等。BindingResult
或Error
中。ModelAndView
,选择一个适合的 ViewResolver
(必须是已经注册到 Spring 容器中的ViewResolver
)返回给DispatcherServlet
。ViewResolver
结合Model
和View
,来渲染视图。WebApplicationContext 是 ApplicationContext 的扩展。它具备 Web 应用程序所需的一些额外功能。它与普通的 ApplicationContext 在解析主题和决定与哪一个 servlet 关联的能力方面有所不一样。
免费Java资料须要本身领取,涵盖了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo高并发分布式等教程,一共30G。
传送门: https://mp.weixin.qq.com/s/JzddfH-7yNudmkjT0IRL8Q