spring之bean管理注解与aop原理

1.
 
导入基本的jar包
    
导入aop的jar包
2.创建类,创建方法
注解的使用:
《spring之bean管理注解与aop原理》

3.创建spring配置文件,引入约束
    第一天做ioc基本功能,引入约束beans
    做spring的ioc注解开发,引入新的约束。
    
《spring之bean管理注解与aop原理》

4.开启注解扫描。

创建对象有四个注解 
    
    目前功能一样,只是区分用途。
@Component
《spring之bean管理注解与aop原理》

@Scope(value=“prototype”) 注解可以用来指定创建对象是单实例还是多实例——这是多实例。默认是单实例

注解注入属性
UserDao类
《spring之bean管理注解与aop原理》

UserService类
在service类中
得到dao对象
定义dao类型属性
@Autowired可以自动完成对象属性的注入。

《spring之bean管理注解与aop原理》

还有一个更好的完成对象属性的注入,可以区别是哪个对象
@Resource(name=”userDao”) 
 里面的name值为@Component值   
必须匹配
    

配置文件和注解混合使用
创建对象操作使用配置文件方式实现。
注入属性的操作使用注解方式实现。
《spring之bean管理注解与aop原理》

《spring之bean管理注解与aop原理》

————————————————————————————————————————————————————————————

AOP概念:
1.aop(Apsect Oriented Programing):面向切面编程,扩展功能不通过修改源代码实现。

2.AOP采取横向抽取机制,取代了传统纵向继承体系重复性代码

AOP原理:
一开始阶段就是想要添加扩展功能需要修改源代码,后来出现了纵向抽取机制解决——
继承
扩展功能的类。但是并不能根本解决——继承类的方法名变化后子类调用的方法名也要跟着变化。
《spring之bean管理注解与aop原理》

最终出现了横向抽取机制,也就是AOP:
底层使用:动态代理方式实现。
《spring之bean管理注解与aop原理》
《spring之bean管理注解与aop原理》

《spring之bean管理注解与aop原理》

《spring之bean管理注解与aop原理》

AOP操作术语:
Pointcut(切入点) 
Advice(通知/增强) 
Aspect(切面) 
《spring之bean管理注解与aop原理》
《spring之bean管理注解与aop原理》

Introduction(引介):引介是一种特殊的通知在不修改类代码的前提下,Introduction可以在运行期为类动态地添加一些方法或Field。 Target(目标对象):代理的目标对象(要增强的类)。 Weaving(织入):是把增强应用到目标的过程——把advice应用到target的过程。 Proxy(代理):一个类被AOP织入增强后,就产生一个结果代理类。

AspectJ简介
AspectJ是一个基于Java语言的面向切面的框架

1.在spring里面进行aop操作,使用aspectj实现

  •    它不是spring的一部分,和spring一起完成aop的操作。

2.使用aspectj实现aop有两种方式
(1)基于AspectJ的xml配置
(2)基于AspectJ的注解方式


操作准备:
1.引入aop的jar包:
《spring之bean管理注解与aop原理》
《spring之bean管理注解与aop原理》

2.创建spring核心配置文件,导入aop的约束
《spring之bean管理注解与aop原理》《spring之bean管理注解与aop原理》

使用表达式配置切入点
常用的表达式:
excution(<访问修饰符>?<返回类型><方法名>(<参数>)<异常>)
excution()
《spring之bean管理注解与aop原理》
《spring之bean管理注解与aop原理》

方法一、基于AspectJ的xml配置aop操作
《spring之bean管理注解与aop原理》
《spring之bean管理注解与aop原理》

method值为增强类里面使用哪个方法作为前置
《spring之bean管理注解与aop原理》
《spring之bean管理注解与aop原理》

log4j介绍
通过lgo4j可以看到程序运行过程中更详细的信息 
1.查看日志

使用
1.导入log4j的jar包
2.复制log4j的配置文件,复制src下面
 
    
log4j.properties
3.可以设置日志级别 info debug
    log4j.rootLogger=info,stdout

    原文作者:AOP
    原文地址: https://blog.csdn.net/AntaoMen/article/details/77652913
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞