SpringAOP2种配置方式(xml方式)

xml方式配置aop

一、编码前准备工作

1.      建项目需要的包和类,如下图所示:


其中aspect里放的是两种方式定义的切面,annotation是注释方式,xml是xml方式

下面两种配置文件也是同样的

2.      在pom.xml内添加需要的依赖包

<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>4.3.2.RELEASE</version>
    </dependency>

    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
    </dependency>

    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjrt</artifactId>
        <version>1.8.9</version>
    </dependency>

    <dependency>
        <groupId>org.aspectj</groupId>
        <artifactId>aspectjweaver</artifactId>
        <version>1.8.9</version>
    </dependency>

</dependencies>

 

二、Dao接口和类代码实现

1.      UserDao

public interface UserDao {
   
public BooleantestUserDao();
}

2.      UserDaoImpl

我这里使用自动扫描的方式注入bean,所以给下面类加入注解

@Component("userDao")
public class UserDaoImpl implements UserDao {
    public Boolean testUserDao() {
        System.out.println("testUserDao!!!!!");
        return true;
    }
}

三、切面类实现

1.      加自动扫描的注解

@Component("userDao")

2.      定义通知

1)        前置通知

public void doBefore(){
    System.out.println("前置通知!!!!");
}

2)        后置通知

public void doAfterReturn(){
    System.out.println("后置通知!!!");
}

3)        最终通知

public void doFinallyReturn(){
    System.out.println("最终通知!!!");
}

4)        异常通知

public void doThrowing(){
    System.out.println("异常通知!!!!");
}

5)        环绕通知

public Object doArround(ProceedingJoinPoint pjp) throws Throwable{
    System.out.println("环绕通知----开始");
    Object o = pjp.proceed();
    System.out.println("环绕通知----结束");
    return o;
}

ProceedingJoinPoint 表示正在执行的方法

Pjp.procees();让该方法执行

四、ApplicationContext-xml配置

1.      添加命名空间

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

2.      自动扫描组件

<context:component-scan base-package="com.neusoft.spring.aop.demo.dao"/>
<context:component-scan base-package="com.neusoft.spring.aop.demo.aspect"/>

3.      配置切面

<aop:config>
       <
aop:aspectid="aspect" ref="aspectxml">
              <
aop:pointcut id="pointCut" expression="execution(* com.neusoft.spring.aop.demo.dao.impl.UserDaoImpl.*(..))"/>
              <
aop:before method="doBefore" pointcut-ref="pointCut"/>
              <
aop:after-returning method="doAfterReturn"pointcut-ref="pointCut"/>
              <
aop:after method="doFinallyReturn" pointcut-ref="pointCut"/>
              <
aop:around method="doArround" pointcut-ref="pointCut"/>
              <
aop:after-throwing method="doThrowing"pointcut-ref="pointCut"/>
       </
aop:aspect>
</
aop:config>

Aspect:配置切面类

Pointcut:配置切入点

Aop:**** :配置通知

五、测试

@Test
public void testXml(){

    ApplicationContext context = new  ClassPathXmlApplicationContext("applicationContext-xml.xml");
    UserDao userDao = context.getBean("userDao",UserDao.class);
    userDao.testUserDao();
}

六、结果

因为这里没有异常,所以没有异常通知。

七、异常通知

1.      让实现类里抛出异常

@Component("userDao")
public class UserDaoImpl implements UserDao {
    public void testUserDao()  {
        System.out.println("testUserDao!!!!!");
       throw new  RuntimeException("异常");
    }
}

2.      查看结果

### 如何在微信中集成和使用 ChatGPT 或百度的文心一言服务 目前,官方并没有直接支持通过微信内置浏览器访问 ChatGPT 的网页版[^1]。然而,对于希望在微信环境中体验类似功能的用户来说,存在几种替代方案: #### 使用第三方小程序或公众号 一些开发者创建了专门的小程序或微信公众账号来间接接入这些AI服务平台。例如,“通义千问”已经上线了微信小程序版本,允许用户更便捷地与其交互。 #### 浏览器内嵌方式 如果想要尝试像文心一言这样的国内产品,在微信内部打开其官方网站也是可行的方法之一。只需点击下方链接即可进入相应页面: - 文心一言:[https://yiyan.baidu.com/](https://yiyan.baidu.com/) 需要注意的是,由于网络环境的不同以及各平台政策的变化,具体可用性和稳定性可能会有所差异。建议定期关注目标平台最新公告获取最准确的信息。 ```python # 示例代码用于说明如何通过Python脚本调用API接口(仅作概念展示) import requests def get_response_from_api(prompt, api_url="http://example.com/api"): response = requests.post(api_url, json={"message": prompt}) return response.json() prompt_text = "你好" result = get_response_from_api(prompt_text) print(result['reply']) ``` 此段代码展示了理论上可以通过编程手段实现与某些开放API对接的方式,但实际上要在微信生态里做到这一点还需要遵循特定的安全指引和技术文档指导[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值