spring学习 spring注解,ioc,aop,spring2特性
1.spring涉及的设计模式,模板模式,单例模式,工厂模式,代理模式,适配器模式
spring mvc自定义拦截器,可以实现对某个路径的controller的拦截,在拦截之前做一些事情,
https://www.cnblogs.com/WuXuanKun/p/6203975.html
https://www.cnblogs.com/suanshun/p/6700200.html
disptachServlet-handlermapping-handlerIncerpetor-handlerAdapter-controller-视图解析器-view.
spring3.0默认对应的HandlerMapping,BeanNameUrlHandlerMapping,更具contorller,bean的name匹配到对应的HandlerMapping。也可以通过SimpleUrlHandlerMapping,配置SimpleUrlHandlerMapping需要指定对应的mapping和interceptors,指定interceptor的话可以在controller方法处理之前搞一些事情,例如权限检查等。启用这个的时候默认的handlerMapping不在生效。
① 客户端的所有请求都交给前端控制器DispatcherServlet来处理,它会负责调用系统的其他模块来真正处理用户的请求。
② DispatcherServlet收到请求后,将根据请求的信息(包括URL、HTTP协议方法、请求头、请求参数、Cookie等)以及HandlerMapping的配置找到处理该请求的Handler(任何一个对象都可以作为请求的Handler)。
③在这个地方Spring会通过HandlerAdapter对该处理器进行封装。
④ HandlerAdapter是一个适配器,它用统一的接口对各种Handler中的方法进行调用。
⑤ Handler完成对用户请求的处理后,会返回一个ModelAndView对象给DispatcherServlet,ModelAndView顾名思义,包含了数据模型以及相应的视图的信息。
⑥ ModelAndView的视图是逻辑视图,DispatcherServlet还要借助ViewResolver完成从逻辑视图到真实视图对象的解析工作。
⑦ 当得到真正的视图对象后,DispatcherServlet会利用视图对象对模型数据进行渲染。
⑧ 客户端得到响应,可能是一个普通的HTML页面,也可以是XML或JSON字符串,还可以是一张图片或者一个PDF文件。
3.spring注解的操作原理,https://blog.csdn.net/u010987379/article/details/52152795,这篇帖子介绍了spring ioc的基本原理,还包括注解的注入
1、 annotition的类型使用关键字@interface而不是interface。它继承了java.lang.annotition.Annotition接口,并非申明了一个interface。
2、 Annotation类型、方法定义是独特的、受限制的。Annotation类型的方法必须申明为无参数、无异常抛出的。这些方法定义了Annotation的成员:方法名称为了成员名,而方法返回值称为了成员的类型。而方法返回值必须为primitive类型、Class类型、枚举类型、Annotation类型或者由前面类型之一作为元素的一位数组。方法的后面可以使用default和一个默认数值来申明成员的默认值,null不能作为成员的默认值,这与我们在非Annotation类型中定义方法有很大不同。Annotation类型和他的方法不能使用Annotation类型的参数,成员不能是generic。只有返回值类型是Class的方法可以在Annotation类型中使用generic,因为此方法能够用类转换将各种类型转换为Class。
3、 Annotation类型又与接口有着近似之处。它们可以定义常量、静态成员类型(比如枚举类型定义)。Annotation类型也可以如接口一般被实现或者继承。
Annotation其实是一种接口。通过Java的反射机制相关的API来访问Annotation信息。相关类(框架或工具中的类)根据这些信息来决定如何使用该程序元素或改变它们的行为。Java语言解释器在工作时会忽略这些Annotation,因此在JVM中这些Annotation是“不起作用”的,只能通过配套的工具才能对这些Annotation类型的信息进行访问和处理。
元注解@Target,@Retention,@Documented,@Inherited
* @Target 表示该注解用于什么地方,可能的 ElemenetType 参数包括:
* ElemenetType.CONSTRUCTOR 构造器声明
* ElemenetType.FIELD 域声明(包括 enum 实例)
* ElemenetType.LOCAL_VARIABLE 局部变量声明
* ElemenetType.TYPE 类,接口(包括注解类型)或enum声明
* @Retention 表示在什么级别保存该注解信息。可选的 RetentionPolicy 参数包括:
* RetentionPolicy.SOURCE 注解将被编译器丢弃
* RetentionPolicy.CLASS 注解在class文件中可用,但会被VM丢弃
* RetentionPolicy.RUNTIME VM将在运行期也保留注释,因此可以通过反射机制读取注解的信息。
* @Documented 将此注解包含在 javadoc 中
例如@controller的注解定义是,定义目标是TYPE。
@RequestMapping 的注解定义是,定义目标是METHOD和TYPE
@Autowired的注解定义是,定义目标是TYPE,FILED(字段)
2.spring 2大特性,spring IOC和spring aop,ioc的技术支持是java的反射机制,通过类的加载器和双亲委派模型实现发射。
aop的技术支持是动态代理机制,包括jdk动态代理和spring的cglib动态代理。
动态代理的功能是可以在指定的方法前后植入某些代码块,变相的增加功能
阐述Spring框架中Bean的生命周期,spring生命周期
① Spring IoC容器找到关于Bean的定义并实例化该Bean。
③ 如果Bean实现了BeanNameAware接口,则将该Bean的id传给setBeanName方法。
④ 如果Bean实现了BeanFactoryAware接口,则将BeanFactory对象传给setBeanFactory方法。
⑤ 如果Bean实现了BeanPostProcessor接口,则调用其postProcessBeforeInitialization方法。
⑥ 如果Bean实现了InitializingBean接口,则调用其afterPropertySet方法。
⑦ 如果有和Bean关联的BeanPostProcessors对象,则这些对象的postProcessAfterInitialization方法被调用。
⑧ 当销毁Bean实例时,如果Bean实现了DisposableBean接口,则调用其destroy方法。
在Web项目中如何获得Spring的IoC容器,获取IOC容器
1 2 | WebApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(servletContext); |
@AutoWired不能继承,但是spring使父类的带有AutoWired的字段也会绑定到子类上
spring在初始化完毕后会将SpringContext放置在web ServletContext中(这个是所有的servlet和listener,filter共享的);
spring mvc在初始化的时候会去将parentContex设置到dispatchServlet中,这样的话在初始化controller中的时候,注入service能够找到spring的bean(getBean的过程中,自己context找不到的话会去parentContext中找(实际上是到BeanFactory中找))
spring常用接口,AppliationContextWare,BeanFactoryAware,InitializingBean,BeanNameAware,BeanPostProcesser,BeanFactoryPostProcessor,FacoryBean
FacoryBean,在bean获取到之后判断bean的类型,如果是Factory类型就会执行getObject方法
AppliationContextWare,bean在初始化的时候会把context设置进来;
BeanFactoryAware,bean在初始化的时候会把BeanFactory设置进来;
InitializingBean,会再bean的初始化是调用afterPropertiesSet方法进行bean的逻辑初始化
BeanPostProcesser,后置处理器,在bean的初始化之前之后会执行,存在变种InstantiationAwareBeanPostProcessor(执行时间populateBean),