spring注解开发及AOP

Spring的bean管理(注解)

  注解介绍

    1 代码里面特殊标记,使用注解可以完成功能

 

    2 注解写法 @注解名称(属性名称=属性值)

 

    3 注解使用在类上面,方法上面 和 属性上面

  Spring注解开发准备

    1 导入jar包

      (1)导入基本的jar包

        

      (2)导入aop的jar包

        

    2 创建类,创建方法

    3 创建spring配置文件,引入约束

    (1)第一天做ioc基本功能,引入约束beans

    (2)做spring的ioc注解开发,引入新的约束

<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns="http://www.springframework.org/schema/beans"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd">

    4 开启注解扫描:一般使用上面的扫描方式

    <!-- 开启注解扫描 
        (1)到包里面扫描类、方法、属性上面是否有注解
    -->
    <context:component-scan base-package="cn.itcast"></context:component-scan>
    
    <!-- 
        扫描属性上面的注解
     -->
    <!-- <context:annotation-config></context:annotation-config> -->

  注解创建对象

    1 在创建对象的类上面使用注解实现

@Component(value="user")
public class User {

    public void add() {
        System.out.println("User......");
    }
}
public class TestAnno {

    @Test
    void testName() throws Exception {
        ApplicationContext context = 
                new ClassPathXmlApplicationContext("bean1.xml");
        User user = (User) context.getBean("user");
        user.add();
    }
}

    

    2 创建对象有四个注解

        

    (1)@Component

    (2)@Controller

    (3)@Service

    (4)@Repository

      目前这四个注解功能是一样的,都创建对象

    3 创建对象单实例还是多实例

@Service(value="user")
@Scope(value="prototype")
public class User {

    public void add() {
        System.out.println("User......");
    }
}

  注解注入属性

    1 创建service类,创建dao类,在service得到dao对象

      注入属性第一个注解 @Autowired

      (1)创建dao和service对象

@Component(value="userDao")
public class UserDao {

    public void add() {
        System.out.println("dao.........");
    }
}
@Service(value="userService")
public class UserService {

    //得到dao对象
    //1 定义dao类型属性
    //在dao属性上面使用注解 完成对象注入
    @Autowired
    private UserDao userDao;
    // 使用注解方式时候不需要set方法
    
    public void add() {
        System.out.println("service...........");
        userDao.add();
    }
}

      注入属性第二个注解 @Resource

@Service(value="userService")
public class UserService {

    // name属性值 写 注解创建dao对象 value值
    @Resource(name="userDao")
    private UserDao userDao;
    
    public void add() {
        System.out.println("service...........");
        userDao.add();
    }
}

配置文件和注解混合使用

  1 创建对象操作使用配置文件方式实现

    <!-- 配置对象 -->
    <bean id="bookService" class="cn.itcast.xmlanno.BookService"></bean>
    <bean id="bookDao" class="cn.itcast.xmlanno.BookDao"></bean>
    <bean id="ordersDao" class="cn.itcast.xmlanno.OrdersDao"></bean>

  2 注入属性的操作使用注解方式实现

    //得到bookdao和ordersdao对象
    @Resource(name="bookDao")
    private BookDao bookDao;
    
    @Resource(name="ordersDao")
    private OrdersDao ordersDao;

AOP概念

  1 aop:面向切面(方面)编程,扩展功能不修改源代码实现

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

  3 aop底层使用动态代理实现

    (1)第一种情况,有接口情况,使用动态代理创建接口实现类代理对象

    (2)第二种情况,没有接口情况,使用动态代理创建类的子类代理对象

AOP原理

  画图分析原理

AOP操作术语

  Joinpoint(连接点): 类里面可以被增强的方法,这些方法称为连接点

  Pointcut(切入点):所谓切入点是指我们要对哪些Joinpoint进行拦截的定义.

  Advice(通知/增强):所谓通知是指拦截到Joinpoint之后所要做的事情就是通知.通知分为前置通知,后置通知,异常通知,最终通知,环绕通知(切面要完成的功能)

  Aspect(切面): 是切入点和通知(引介)的结合

  Introduction(引介):引介是一种特殊的通知在不修改类代码的前提下, Introduction可以在运行期为类动态地添加一些方法或Field.

  Target(目标对象):代理的目标对象(要增强的类)

  Weaving(织入):是把增强应用到目标的过程.

            把advice 应用到 target的过程

  Proxy(代理):一个类被AOP织入增强后,就产生一个结果代理类

Spring的aop操作

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

    (1)aspectj不是spring一部分,和spring一起使用进行aop操作

    (2)Spring2.0以后新增了对AspectJ支持

    2 使用aspectj实现aop有两种方式

    (1)基于aspectj的xml配置

    (2)基于aspectj的注解方式

  Aop操作准备

    1 除了导入基本的jar包之外,还需要导入aop相关的jar包

      

    2 创建spring核心配置文件,导入aop的约束

  使用表达式配置切入点

    1 切入点:实际增强的方法

    2 常用的表达式

      execution(<访问修饰符>?<返回类型><方法名>(<参数>)<异常>)

      (1)execution(* cn.itcast.aop.Book.add(..))

      (2)execution(* cn.itcast.aop.Book.*(..))

      (3)execution(* *.*(..))

      (4) 匹配所有save开头的方法 execution(* save*(..))

 

  Aspectj的aop操作

    <!-- 1  配置对象 -->
    <bean id="book" class="cn.itcast.aop.Book"></bean>
    <bean id="myBook" class="cn.itcast.aop.MyBook"></bean>
    
    <!-- 2 配置aop操作 -->
    <aop:config>
        <!-- 2.1 配置切入点 -->
        <aop:pointcut expression="execution(* cn.itcast.aop.Book.*(..))" id="pointcut1"/>
        
        <!-- 2.2 配置切面 
            把增强用到方法上面
        -->
        <aop:aspect ref="myBook">
            <!-- 配置增强类型 
                method: 增强类里面使用哪个方法作为前置
            -->
            <aop:before method="before1" pointcut-ref="pointcut1"/>
            
            <aop:after-returning method="after1" pointcut-ref="pointcut1"/>
            
            <aop:around method="around1" pointcut-ref="pointcut1"/>
        </aop:aspect>
    </aop:config>
public class MyBook {

    public void before1() {
        System.out.println("前置增强......");
    }
    
    public void after1() {
        System.out.println("后置增强......");
    }
    
    //环绕通知
    public void around1(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
        //方法之前
        System.out.println("方法之前.....");
        
        //执行被增强的方法
        proceedingJoinPoint.proceed();
        
        //方法之后
        System.out.println("方法之后.....");
    }
}

猜你喜欢

转载自www.cnblogs.com/kpsmile/p/10122414.html