Spring的核心接口
ContextLoaderListener接口
Create a new ContextLoaderListenerthat will create a web application context based on the "contextClass" and "contextConfigLocation" servlet context-params. See ContextLoadersuperclass documentation for details on default values for each.
This constructor is typically used when declaring ContextLoaderListener as a <listener> within web.xml, where a no-arg constructor is required.
这个接口实现了J2EE的ServletContextListener接口
通过listener 像Servlet容器注册 Web容器启动时 初始化Spring上下文的信息
<!-- 加载Spring容器 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext-core.xml</param-value>
</context-param>
<!-- 通过listener 像Servlet容器注册 Web容器启动时 初始化context-param的配置信息。-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
BeanFactory接口
Spring通过BeanFactory接口的getBean来拿到我们所配置Bean的实列,交给Spring管理的Bean全部默认是单例。
以下是批量扫描初始化Bean 交给Spring管理
<context:component-scan base-package="com.sk.service.*"></context:component-scan>
IOC
ioc 是依赖注入,当我们的成员变量是Spring的一个Bean的时候,那这个成员变量可以由Spring帮我们注入(Spring会通过反射调用Set方法)
依赖注入也叫控制反转,以前编程完完全全控制在我自己的手里。用了Spring之后 成员变量的初始化过程控制过程反转到Spring手里。
注解用法:
@Autowired
DemoService demoService;
AOP
从代理的原理我们知道,代理的目的是调用目标方法时可以转而执行InvocationHandler的invoke方法,所以如何在InvocationHandler上做文章就是Spring实现AOP的关键所在。
Spring的AOP实现遵守AOP联盟的约定,同时Spring又扩展了它。增加了 PointCut Advisor接口使得其更加灵活
<!-- 切面逻辑类的对象 -->
<bean id="myInterceptor" class="com.sk.util.MyInterceptor"></bean>
<aop:config>
<!-- 在add方法上加各种各样的我们切入进来的逻辑 -->
<aop:pointcut expression="execution(public * com.sk.service..*.*(..))" id="servicePointcut"/>
<aop:aspect id = "logAspect" ref="myInterceptor">
<!-- aop:pointcut可以加到aspect的里面来 加到里面的话 只能是logAspect 这个aspect使用 -->
<aop:before method="before" pointcut-ref="servicePointcut"/>
<aop:after method="after" pointcut-ref="servicePointcut"/>
</aop:aspect>
</aop:config>
当我们执行的时候 符合我们execution(public * com.sk.service..*.*(..))语法要求的方法的时候,
它会在方法执行之前 执行before方法(logInterceptor的before方法) 方法执行之后 执行after方法。
Junit测试
@Test
public void testIoc() {
BeanFactory beanFactory = new ClassPathXmlApplicationContext("applicationContext-core.xml");
DemoService demoService = beanFactory.getBean(DemoService.class);
demoService.testAop();
}
利用JoinPoint模拟AOP 实现事物管理
JoinPoint:连接点(AOP切面切到我们程序时的连接点,切入的那个点)
上面的配置保持不变,首先给我们的Service 加一个自定义的注解
@Inherited
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD, ElementType.TYPE})
public @interface MyAnnotation {
public String transaction() default "";
}
@Service
public class DemoServiceImpl implements DemoService{
@Override
@MyAnnotation(transaction= "transaction")
public void testAop() {
System.out.println("excute Service***********");
}
}
完善我们的切面逻辑类
当我们的切面发现这个注解的时候 就进行事物的控制
public class MyInterceptor {
public void before(JoinPoint jp) throws Exception {
MyAnnotation myAnnotation =getHandlerChain(jp);
System.out.println("方法开始通过AOP拿到方法上的注解-开始事物"+myAnnotation.transaction());
}
public void after(JoinPoint jp)throws Exception {
MyAnnotation myAnnotation =getHandlerChain(jp);
System.out.println("放过结束通过AOP拿到方法上的注解-结束事物"+myAnnotation.transaction());
}
// 取方法或者类上的HandlerChain注解,方法上的优先
private MyAnnotation getHandlerChain(JoinPoint jp) throws Exception {
MethodSignature methodSignature = (MethodSignature) jp.getSignature();
Method realMethod = jp.getTarget().getClass().getDeclaredMethod(methodSignature.getName(), methodSignature.getParameterTypes());
MyAnnotation myAnnotation = realMethod.getAnnotation(MyAnnotation.class);
if(myAnnotation==null) {
Class<? extends Object> cls = jp.getTarget().getClass();
myAnnotation = (MyAnnotation) cls.getAnnotation(MyAnnotation.class);
}
return myAnnotation;
}
}
打印结果
方法开始通过AOP拿到方法上的注解-开始事物transaction
excute Service***********
放过结束通过AOP拿到方法上的注解-结束事物transaction
这里只是打印模拟,项目中需要和JDBC(或者Mybatis Hibernate)结合,进而控制数据库transaction的开启和关闭
Spring新框架WebFlux
Spring的核心接口的更多相关文章
- spring 的核心接口
spring有两个核心接口,BeanFactory 和ApplicationContext ,其中ApplicationContext 是BeanFactory的子接口.他们代表了Spring容器. ...
- Spring事务核心接口
- spring中基础核心接口总结
spring中基础核心接口总结理解这几个接口,及其实现类就可以快速了解spring,具体的用法参考其他spring资料 1.BeanFactory最基础最核心的接口重要的实现类有:XmlBeanFac ...
- Spring Boot REST(一)核心接口
Spring Boot REST(一)核心接口 Spring 系列目录(https://www.cnblogs.com/binarylei/p/10117436.html) SpringBoot RE ...
- 【Spring】Spring的事务管理 - 1、Spring事务管理概述(数据库事务、Spring事务管理的核心接口)
Spring事务管理概述 文章目录 Spring事务管理概述 数据库事务 什么是Spring的事务管理? Spring对事务管理的支持 Spring事务管理的核心接口 Platform Transac ...
- Spring8:一些常用的Spring Bean扩展接口
前言 Spring是一款非常强大的框架,可以说是几乎所有的企业级Java项目使用了Spring,而Bean又是Spring框架的核心. Spring框架运用了非常多的设计模式,从整体上看,它的设计严格 ...
- spring IOC核心原理
下面来了解一下Spring到底是怎么运行的. public static void main(String[] args) { ApplicationContext context = new Fil ...
- spring之BeanFactoryAware接口
springBeanFactoryAware (转)要直接在自己的代码中读取spring的bean,我们除了根据常用的set外,也可以通过spring的BeanFactoryAware接口实现,只要实 ...
- spring技术核心概念纪要
一.背景 springframework 从最初的2.5版本发展至今,期间已经发生了非常多的修正及优化.许多新特性及模块的出现,使得整个框架体系显得越趋庞大,同时也带来了学习及理解上的困难. 本文阐述 ...
随机推荐
- Chrome浏览器自动填充<input>标签的密码
问题:登录页面登录时,Chrome浏览器保存了用户名和密码,在其他页面管理其他的账户和密码时,密码框先是显示正确的密码,然后一闪而过被覆盖. 原因:问了技术主管才得知,Chrome浏览器中的,保存用户 ...
- vertx的ShardData共享数据
数据类型 一共4种 synchronous shared maps (local) asynchronous maps (local or cluster-wide) asynchronous loc ...
- Nginx负载-nginx转发到Swoole服务器(nginx配置文件变更)
- java springboot 大文件分片上传处理
参考自:https://blog.csdn.net/u014150463/article/details/74044467 这里只写后端的代码,基本的思想就是,前端将文件分片,然后每次访问上传接口的时 ...
- ubuntu快速部署gitlab汉化容器
前言:gitlab的原理我就不扯了(看这个https://www.jianshu.com/p/567207ac51cd),下面直接上操作 1.前提: a.要有docker的运行环境,用service ...
- windows下安装Python虚拟环境virtualenvwrapper-win
1 前言 由于Python的版本众多,还有Python2和Python3的争论,因此有些软件包或第三方库就容易出现版本不兼容的问题. 通过 virtualenv 这个工具,就可以构建一系列 虚拟的 ...
- nginx 平滑更新
1.更新nginx源 #centos6的nginx源 #centos7的话吧url 的6改为7就行了 vim /etc/yum.repos.d/nginx.repo [nginx] name=ngin ...
- 基本urllib库
urlib库 urllib库是Python中一个最基本的网络请求库.可以模拟浏览器的行为,向指定的服务器发送一个请求,并可以保存服务器返回的数据. urlopen函数: 在Python3的urllib ...
- GLSL ES 中的存储变量修饰符(const/attribute/uniform/varying/in/centroid in/out/centroid out)
GLSL ES 3.00 中支持的存储变量修饰符 变量名称 作用 示例 const 编译过程常量,或者函数的只读参数 const vec3 zAxis = vec3 (0.0, 0.0, 1.0); ...
- 禁止Centos7系统yum自动下载更新
安装Centos7后,系统自动更新状态默认为开启,若禁止系统自动更新需要手动关闭. 1.进入yum目录 [root@localhost ~]$ cd /etc/yum 2.编辑yum-cron.co ...