传智播客 Spring学习 ,注解和AOP

本文介绍了Spring框架中的注解使用方法及其优势,包括@Component等注解的应用场景,并探讨了AOP的原理和实现方式,通过示例代码帮助读者深入理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   今天继续复习Spring,黎老师讲的不错,经过这段时间的学习和在项目中对spring的使用,再看黎老师的视频,理解起来也就容易了。代码也敲了一遍,效果不错。今天主要看了注解和AOP这部分。
使用注解, 通过在classpath自动扫描方式把组件纳入spring容器中管理
   前面的学习都是使用XML的bean定义来配置组件。在一个稍大的项目中,通常会有上百个组件,如果这些这组件采用xml的bean定义来配置,显然会增加配置文件的体积,查找及维护起来也不太方便。spring2.5为我们引入了组件自动扫描机制,他可以在类路径底下寻找标注了@Component、@Service、@Controller、@Repository注解的类,(它就认为这些类是要叫给Spring管理的)并把这些类纳入进spring容器中管理。它的作用和在xml文件中使用bean节点配置组件是一样的。要使用自动扫描机制,我们需要打开以下配置信息:
<beans xmlns="
http://www.springframework.org/schema/beans"
       xmlns:xsi="
http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="
http://www.springframework.org/schema/context"
       xsi:schemaLocation="
http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-2.5.xsd">
          <context:component-scan base-package="cn.itcast"/>
</beans>
1.其中base-package为需要扫描的包(含子包)。
@Service用于标注业务层组件(service层)、 @Controller用于标注控制层组件(如struts中的action)把action交给Spring管理、@Repository用于标注数据访问组件,即DAO组件。而@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。目前这四个注解作用都一样,Spring还没有对他们做特殊处理。
 2. 注解由注解处理器进行解析,注解处理器在xml中配置
 <context:component-scan base-package=“cn.itcast”/>包括<context:annotation-config/>中的所有注解
 这两个配置的作用就是注册注解处理器
3.@PostConstruct 指定初始化的方法,bean实例化以后就会调用这个方法
  @PreDestroy指定销毁方法,bean关闭时就会调用这个方法
使用注解时,使用getBean()方法获取bean实例使用类的简单名称(首字母小写)作为参数。
 可以使用@Service(“personService”)这样的方式设置bean的名称
 @Scope(“prototype”)修改bean的作用域

 Aop 的原理,aop的主要作用就是使用代理模式拦截业务方法,客户端调用代理对象,代理对象实现了目标对象的所有接口。通过代理对象的调用,代理对象可以把方法的调用委派给目标对象(代理对象的方法里头调用了目标对象的方法)
使用Proxy的前提是,目标对象必须面向接口
横切性关注点
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

import cn.itcast.service.impl.PersonServiceBean;

public class JDKAopFactory implements InvocationHandler {
   //目标对象
private Object targetObject;
 //为目标对象创建代理对象
 public Object createProxyIntance(Object targetObject){
 this.targetObject=targetObject;
 //代理会实现目标对象的接口中所有方法
 /*newProxyInstance的三个参数:
      loader - 定义代理类的类加载器
        interfaces - 代理类要实现的接口列表
      h - 指派方法调用的调用处理程序
    返回:
     一个带有代理类的指定调用处理程序的代理实例,它由指定的类加载器定义,并实现指定的接口 
  */
 return Proxy.newProxyInstance(this.targetObject.getClass().getClassLoader(), this.targetObject.getClass().getInterfaces(), this);
 }
//proxy代理对象,method被拦截到的方法,调用代理对象方法的时候,会调用上面第三个参数(this)的invoke方法,
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {


    PersonServiceBean bean=(PersonServiceBean)this.targetObject;
    Object result=null;
    if(bean.getUser()!=null){
    //调用目标对象的invoke方法
    //把方法的调用委派给目标对象
     result=method.invoke(targetObject, args);
    }
  
    return result;
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值