权限管理demo-获取Spring上下文工具
1. spring是一个轻量级的开源框架,简化了java应用的开发。它的核心是Ioc和Aop.
好处:方便解耦,简化开发。AOP编程的支持。声明式事务的支持。测试方便。方便集成各种常用框架。
2. Ioc, 控制反转。将对象创建权由开发者反转给spring容器,并通过容器管理对象的生命周期。
AOP, 面向切面编程。针对目标对象进行动态代理,实现功能增强。减少重复代码,降低主业务与此业务的耦合度。比如记录日志,权限控制
3. IoC容器(也称spring容器)本质上就是创建并管理类的实例的工厂,在spring框架中,主要有两个工厂接口:BeanFactory和ApplicationContext.ApplicationContext继承了BeanFactory,在spring容器初始化的时候便会创建bean, 而BeanFactory是延迟加载,用到的时候才会初始化bean.
4. Spring IoC容器配置bean信息的方式有xml配置方式和注解方式
***xml配置方式:bean标签
***注解方式:@Component @Controller @Service @Repository, 需要使用context:component-scan标签配合使用
5. Spring IoC容器的创建主要有两种场景:
*** 非web环境:主要通过ApplicationContext接口的两个实现类来完成:ClasspathXmlApplicationContext和 FileSystemXmlApplicationContext
***web环境:主要通过ContextLoaderListener(实现ServletContextListener接口)创建webApplicationContext后,放入ServerletContext中。
6. DI : bean工厂在生成bean对象的时候,动态地将依赖的对象注入到bean组件中
***依赖注入的方式:构造方法注入 、set方法注入(手动装配方式、自动装配方式)
***手动装配方式(xml) : bean标签的子标签property, 需要在类中指定set方法。
***自动装配方式(注解):@Autowired @Resource
7. Spring AOP实现原理:动态代理技术(JDK的动态代理和CGLIB动态代理,根据是否实现接口来选择使用哪种代理方式)
8. web服务器(servlet容器): tomcat\jetty等
9. web容器:ServletContext
10. web容器初始化过程
(1)web服务器(tomcat)启动会加载web.xml(启动ContextLoaderListener监听器)
(2)web服务器启动后,会创建ServletContext(web上下文,也就是web容器),此时会触发ContextLoaderListener监听器的contextInitialized()方法。
(3)contextInitialized()方法中会调用initWebApplicationContext()方法,该方法负责创建Spring容器和生产Bean对象。
initWebApplicationContext()方法负责创建WebApplicationContext(实际创建的是此接口的默认实现类XmlWebApplicationContext, web环境中的真正容器)
(4)加载spring配置文件,并创建beans。通过configureAndRefreshWebApplicationContext()方法
(5)将spring容器context挂载到ServletContext 这个web容器上下文中。通过servletContext.setAttribute()方法。
11. web三类八种监听器:
***监听域对象的生命周期:
*ServletContextListener:
*创建:服务器启动
*销毁:服务器正常关闭
*spring ContextLoaderListener(服务器启动时负责加载Spring配置文件)
*HttpSessionListener
*创建:第一次访问request.getHttpSession();
*销毁:调用invalidate();非法关闭;过期
*ServletRequestListener
*创建:每一次访问
*销毁:响应结束
***监听域对象的属性:(添加、删除、替换)
* ServletContextAttributeListener
* HttpSessionAttributeListener
* ServletRequestAttributeListener
***监听HttpSession中JavaBean的改变:
* HttpSessionBindingListener(HttpSession和JavaBean对象的绑定和解绑)
* HttpSessionActivationListener(HttpSession的序列化,活化、钝化)
12. spring容器初始化过程:
1、ResourceLoader从存储介质中加载Spring配置信息,并使用Resource表示这个配置文件的资源;
2、BeanDefinitionReader读取Resource所指向的配置文件资源,然后解析配置文件。配置文件中每一个<bean>解析成一个BeanDefinition对象,并保存到BeanDefinitionRegistry中;
3、容器扫描BeanDefinitionRegistry中的BeanDefinition,使用Java的反射机制自动识别出Bean工厂后处理后器(实现BeanFactoryPostProcessor接口)的Bean,然后调用这些Bean工厂后处理器对BeanDefinitionRegistry中的BeanDefinition进行加工处理。主要完成以下两项工作:
1)对使用到占位符的<bean>元素标签进行解析,得到最终的配置值,这意味对一些半成品式的BeanDefinition对象进行加工处理并得到成品的BeanDefinition对象;
2)对BeanDefinitionRegistry中的BeanDefinition进行扫描,通过Java反射机制找出所有属性编辑器的Bean(实现java.beans.PropertyEditor接口的Bean),并自动将它们注册到Spring容器的属性编辑器注册表中(PropertyEditorRegistry);
4.Spring容器从BeanDefinitionRegistry中取出加工后的BeanDefinition,并调用InstantiationStrategy着手进行Bean实例化的工作;
5.在实例化Bean时,Spring容器使用BeanWrapper对Bean进行封装,BeanWrapper提供了很多以Java反射机制操作Bean的方法,它将结合该Bean的BeanDefinition以及容器中属性编辑器,完成Bean属性的设置工作;
6.利用容器中注册的Bean后处理器(实现BeanPostProcessor接口的Bean)对已经完成属性设置工作的Bean进行后续加工,直接装配出一个准备就绪的Bean。
13. <context:property-placeholder location="classpath:db.properties" />使用PropertyPlaceholderConfigurer类实现。
14. IoC容器创建Bean对象源码分析:(AbstractApplicationContext)
@Override
public void refresh() throws BeansException, IllegalStateException {
synchronized (this.startupShutdownMonitor) {
// Prepare this context for refreshing.
prepareRefresh(); //1.创建真正的Spring容器(DefaultListableBeanFactory)
//2.加载BeanDefition(描述要初始化的Bean的信息)
//3.将BeanDefition注册到BeanDefitionRegistry
// Tell the subclass to refresh the internal bean factory.
ConfigurableListableBeanFactory beanFactory = obtainFreshBeanFactory(); // Prepare the bean factory for use in this context.
prepareBeanFactory(beanFactory); try {
// Allows post-processing of the bean factory in context subclasses.
postProcessBeanFactory(beanFactory); //执行实现了BeanFactoryPostProcessor接口的Bean
//比如PropertyPlaceHolderConfigurer(context:property-placeholer)就是此处被调用的,替换掉BeanDefition中的占位符(${})中的内容
// Invoke factory processors registered as beans in the context.
invokeBeanFactoryPostProcessors(beanFactory); //注册BeanPostProcessor(后置处理器)
//比如容器自动装载了一个AutowiredAnnotationBeanPostProcessor后置处理器(实现@Autowired注解功能)
// Register bean processors that intercept bean creation.
registerBeanPostProcessors(beanFactory); // Initialize message source for this context.
initMessageSource(); // Initialize event multicaster for this context.
initApplicationEventMulticaster(); // Initialize other special beans in specific context subclasses.
onRefresh(); // Check for listener beans and register them.
registerListeners(); //初始化非懒加载方式的单例Bean实例
// Instantiate all remaining (non-lazy-init) singletons.
finishBeanFactoryInitialization(beanFactory); // Last step: publish corresponding event.
finishRefresh();
} catch (BeansException ex) {
if (logger.isWarnEnabled()) {
logger.warn("Exception encountered during context initialization - " +
"cancelling refresh attempt: " + ex);
} // Destroy already created singletons to avoid dangling resources.
destroyBeans(); // Reset 'active' flag.
15. bean标签
***bean标签作用:
***用于配置对象让 spring 来创建的。
***默认情况下它调用的是类中的无参构造函数。如果没有无参构造函数则不能创建成功。
***bean标签属性:
***id:给对象在容器中提供一个唯一标识。用于获取对象。
***class:指定类的全限定类名。用于反射创建对象。默认情况下调用无参构造函数。
***scope:指定对象的作用范围。
* singleton :默认值,单例的(在整个容器中只有一个对象).
* prototype :多例的.
* request :WEB 项目中,Spring 创建一个 Bean 的对象,将对象存入到 request 域中.
* session :WEB 项目中,Spring 创建一个 Bean 的对象,将对象存入到 session 域中.
* global session :WEB 项目中,应用在 Portlet 环境.如果没有 Portlet 环境那么globalSession 相当于 session.
***init-method:指定类中的初始化方法名称。
***destroy-method:指定类中销毁方法名称。比如DataSource的配置中一般需要指定destroy-method=“close”。
***bean的作用范围:
***单例对象:scope="singleton"
***一个应用只有一个对象的实例。它的作用范围就是整个引用。
***生命周期:
*对象出生:当应用加载,创建容器时,对象就被创建了。
*对象活着:只要容器在,对象一直活着。
*对象死亡:当应用卸载,销毁容器时,对象就被销毁了。
***多例对象:scope="prototype"
***每次访问对象时,都会重新创建对象实例。
***生命周期:
*对象出生:当使用对象时,创建新的对象实例。
*对象活着:只要对象在使用中,就一直活着。
*对象死亡:当对象长时间不用时,被 java 的垃圾回收器回收了。
16. 实例化bean的三种方式
(1)默认使用无参构造函数
(2)静态工厂
(3)实例工厂
17. spring中注解:
@Autowired相当于<property name="" ref="">
***默认按类型装配(byType)
***这个注解是spring自身的
***默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false)
***如果我们想使用名称装配可以结合@Qualifier注解进行使用
@Qualifier
***在自动按照类型注入的基础之上,再按照 Bean 的 id 注入。
***它在给字段注入时不能独立使用,必须和@Autowire 一起使用;但是给方法参数注入时,可以独立使用。
@Resource
***默认按照名称(byName)进行装配,名称可以通过name属性进行指定
***这个注解属于J2EE的
***如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称查找,当找不到与名称匹配的bean时才按照类型进行装配。
***但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。
@Value
***给基本类型和String类型注入值
***可以使用占位符获取属性文件中的值。
@Value(“${name}”)//name是properties文件中的key
private String name;
@Configuration
***从Spring3.0,@Configuration用于定义配置类,可替换xml配置文件
***相当于<beans>根标签
***配置类内部包含有一个或多个被@Bean注解的方法,这些方法将会被AnnotationConfigApplicationContext或AnnotationConfigWebApplicationContext类进行扫描,并用于构建bean定义,初始化Spring容器。
- 属性:
value:用于指定配置类的字节码
- 示例代码:
@Configuration
public class SpringConfiguration {
//spring容器初始化时,会调用配置类的无参构造函数
public SpringConfiguration(){
System.out.println(“容器启动初始化。。。”);
}
}
@Bean
***@Bean标注在方法上(返回某个实例的方法),等价于spring配置文件中的<bean>
***作用为:注册bean对象
***主要用来配置非自定义的bean,比如DruidDataSource、SqlSessionFactory
***name:给当前@Bean 注解方法创建的对象指定一个名称(即 bean 的 id)。
***如果不指定,默认与标注的方法名相同
***@Bean注解默认作用域为单例singleton作用域,可通过@Scope(“prototype”)设置为原型作用域;
- 示例代码:
@Configuration
public class SpringConfiguration {
//spring容器初始化时,会调用配置类的无参构造函数
public SpringConfiguration(){
System.out.println(“容器启动初始化。。。”);
}
@Bean
@Scope(“prototype”)
public UserService userService(){
return new UserServiceImpl(1,“张三”);
}
}
@ComponentScan
***相当于context:component-scan标签
***组件扫描器,扫描@Component、@Controller、@Service、@Repository注解的类。
***该注解是编写在类上面的,一般配合@Configuration注解一起使用。
***basePackages:用于指定要扫描的包。
***value:和basePackages作用一样。
@PropertySource
***加载properties配置文件
***编写在类上面
***相当于context:property-placeholder标签
- 属性
value[]:用于指定properties文件路径,如果在类路径下,需要写上classpath
- 示例代码
@Configuration
@PropertySource(“classpath:jdbc.properties”)
public class JdbcConfig {
@Value("${jdbc.driver}")
private String driver;
@Value("${jdbc.url}")
private String url;
@Import
***用来组合多个配置类
***相当于spring配置文件中的import标签
***在引入其他配置类时,可以不用再写@Configuration 注解。当然,写上也没问
@Configuration
@ComponentScan(basePackages = "com.kkb.spring")
@Import({ JdbcConfig.class})
public class SpringConfiguration {
}
@Configuration
@PropertySource("classpath:jdbc.properties")
public class JdbcConfig{
}
18. AOP编程术语:
切面:切入点和通知的结合。
织入:将切面织入到目标对象的目标方法的过程
连接点(Joinpoint):目标对象中可以被切面织入的方法
切入点(pointcut):目标对象中真正被切面切入的方法
通知:拦截到连接点后要做的事情
顾问(Advisor): 切面的一种,能将通知以更为复杂的方式织入到目标对象。
19. 通知类型
***通知类型(五种):前置通知、后置通知、最终通知、环绕通知、异常抛出通知。
***前置通知:
***执行时机:目标对象方法之前执行通知
***配置文件:<aop:before method="before" pointcut-
ref="myPointcut"/>
***应用场景:方法开始时可以进行校验
***后置通知:
***执行时机:目标对象方法之后执行通知,有异常则不执行了
***配置文件:<aop:after-returning method="afterReturning" pointcut-ref="myPointcut"/>
***应用场景:可以修改方法的返回值
***最终通知:
***执行时机:目标对象方法之后执行通知,有没有异常都会执行
***配置文件:<aop:after method="after" pointcut-ref="myPointcut"/>
***应用场景:例如像释放资源
***环绕通知:
***执行时机:目标对象方法之前和之后都会执行。
***配置文件:<aop:around method="around" pointcut-ref="myPointcut"/>
***应用场景:事务、统计代码执行时机
***异常抛出通知:
***执行时机:在抛出异常后通知
***配置文件:<aop:after-throwing method=" afterThrowing " pointcut- ref="myPointcut"/>
***应用场景:包装异常
20.
1. 事务:指的是逻辑上一组操作,组成这个事务的各个执行单元,要么一起成功,要么一起失败!
2. 事务的特性
* 原子性
* 一致性
* 隔离性
* 持久性
3. 如果不考虑隔离性,引发安全性问题
* 读问题:
* 脏读:
* 不可重复读:
* 虚读:
4. 如何解决安全性问题
* 读问题解决,设置数据库隔离级别
21. spring框架的事务管理相关
1. PlatformTransactionManager接口 -- 平台事务管理器.(真正管理事务的类)。该接口有具体的实现类,根据不同的持久层框架,需要选择不同的实现类!
2. TransactionDefinition接口 -- 事务定义信息.(事务的隔离级别,传播行为,超时,只读)
3. TransactionStatus接口 -- 事务的状态
4. 总结:上述对象之间的关系:平台事务管理器真正管理事务对象.根据事务定义的信息TransactionDefinition 进行事务管理,在管理事务中产生一些状态.将状态记录到TransactionStatus中
5. PlatformTransactionManager接口中实现类和常用的方法
1. 接口的实现类
* 如果使用的Spring的JDBC模板或者MyBatis框架,需要选择DataSourceTransactionManager实现类
* 如果使用的是Hibernate的框架,需要选择HibernateTransactionManager实现类
2. 该接口的常用方法
* void commit(TransactionStatus status)
* TransactionStatus getTransaction(TransactionDefinition definition)
* void rollback(TransactionStatus status)
6. TransactionDefinition
1. 事务隔离级别的常量
* static int ISOLATION_DEFAULT -- 采用数据库的默认隔离级别
* static int ISOLATION_READ_UNCOMMITTED
* static int ISOLATION_READ_COMMITTED
* static int ISOLATION_REPEATABLE_READ
* static int ISOLATION_SERIALIZABLE
2. 事务的传播行为常量(不用设置,使用默认值)
* 先解释什么是事务的传播行为:解决的是业务层之间的方法调用!!
* PROPAGATION_REQUIRED(默认值) -- A中有事务,使用A中的事务.如果没有,B就会
开启一个新的事务,将A包含进来.(保证A,B在同一个事务中),默认值!!
* PROPAGATION_SUPPORTS -- A中有事务,使用A中的事务.如果A中没有事务.那么B也不使用事务.
* PROPAGATION_MANDATORY -- A中有事务,使用A中的事务.如果A没有事务.抛出异常.
* PROPAGATION_REQUIRES_NEW -- A中有事务,将A中的事务挂起.B创建一个新的事务.(保证A,B没有在一个事务中)
* PROPAGATION_NOT_SUPPORTED -- A中有事务,将A中的事务挂起.
* PROPAGATION_NEVER -- A中有事务,抛出异常.
* PROPAGATION_NESTED -- 嵌套事务.当A执行之后,就会在这个位置设置一个保存点.如果B没有问题.执行通过.如果B出现异常,运行客户根据需求回滚(选择回滚到保存点或者是最初始状态)
权限管理demo-获取Spring上下文工具的更多相关文章
- ASP.NET MVC+EF框架+EasyUI实现权限管理系列(6)- EF上下文实例管理
原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(6)- EF上下文实例管理 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇) (1):框架搭建 ( ...
- mvc 权限管理 demo
http://blog.csdn.net/zht666/article/details/8529646 new http://www.cnblogs.com/fengxing/archive/2012 ...
- JAVA获取Spring上下文
1. 添加监听 public class SpringContextListener implements ServletContextListener { //获取spring注入的bean对象 p ...
- 第一章 权限管理DEMO简介
源代码GitHub:https://github.com/ZhaoRd/Zrd_0001_AuthorityManagement 1.系列介绍 工作已有五年之久,一直有想通过博客写点自己知道的,在博客 ...
- 基于Spring DM管理的Bundle获取Spring上下文对象及指定Bean对象
在讲述服务注册与引用的随笔中,有提到context.getServiceReferences()方法,通过该方法可以获取到OSGI框架容器中的指定类型的服务引用,从而获取到对应的服务对象.同时该方法还 ...
- 获取spring上下文 - applicationContext
前言 spring上下文是spring容器抽象的一种实现.将你需spring帮你管理的对象放入容器的一种对象,ApplicationContext是一维护Bean定义以及对象之间协作关第的高级接口. ...
- 五)Spring + Quartz 复杂业务的两个问题:获取Spring上下文 和 自动注入服务类
配置如下: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http:// ...
- 获取spring上下文的bean 工具类
有些场景我们不属于controller,service,dao,但是我们需要从spring中得到spring容器里面的bean.这时候我们需要一个类继承 ApplicationContextAware ...
- 权限管理3-整合Spring Security
一.Spring Security介绍 1.框架介绍 Spring 是一个非常流行和成功的 Java 应用开发框架.Spring Security 基于 Spring 框架,提供了一套 Web 应用安 ...
随机推荐
- node有哪些坑?
const server = http.createServer((req, res) => {} const server = http.createServer((res, req) =&g ...
- C++遍历路径下的所有文件
intptr_t类型用于记录文件夹句柄,注意该类型不是指针类型,而是int型的重定义. _finddata_t结构体类型用于记录文件信息. _finddata_t结构体定义如下 struct _fin ...
- mkpasswd命令
全称mkpasswd make password(用来生成密码的一个工具):随机生成一些高强度的密码,默认生成9位由大小写字母,特殊符号和数字的密码 [root@master ~]# yum inst ...
- 配置selenium grid
本文对Selenium Grid进行了完整的介绍,从环境准备到使用Selenium Grid进行一次完整的多节点分布式测试. 运行环境为Windows 10,Selenium版本为 3.5.0,Chr ...
- Neo4j图数据库使用
最近在处理一些图的数据,主要是有向图,如果图的节点不是特别大可以直接加载到内存里来处理,但是当图的节点个数特别大时,内存就放不下了:我 们牵涉到的图的节点数最大可以达到数亿个节点,已经超出的机器内存的 ...
- 剑指Offer 56. 删除链表中重复的结点 (链表)
题目描述 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. 例如,链表1->2->3->3->4->4->5 处理后 ...
- 后台获取用户登录token 和获取前端参数方法
//获取request请求中所有参数 Enumeration<String> names = request.getParameterNames(); HashMap<String, ...
- 着色器语言 GLSL (opengl-shader-language)入门大全
基本类型: 类型 说明 void 空类型,即不返回任何值 bool 布尔类型 true,false int 带符号的整数 signed integer float 带符号的浮点数 floating s ...
- Linux下查看CPU型号,内存大小,硬盘空间的命令(详解)
1 查看CPU 1.1 查看CPU个数 # cat /proc/cpuinfo | grep "physical id" | uniq | wc -l 2 **uniq命令:删除重 ...
- hadoop 单机模式 伪分布式 完全分布式区别
1.单机(非分布式)模式 这种模式在一台单机上运行,没有分布式文件系统,而是直接读写本地操作系统的文件系统,一般仅用于本地MR程序的调试 2.伪分布式运行模式 这种模式也是在一台单机上运行,但用不同的 ...