java args例子_Spring AOP中使用args表达式的方法示例

本文实例讲述了Spring AOP中使用args表达式的方法。分享给大家供大家参考,具体如下:

一 配置

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"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-4.0.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-4.0.xsd

http://www.springframework.org/schema/aop

http://www.springframework.org/schema/aop/spring-aop-4.0.xsd">

base-package="org.crazyit.app.service

,org.crazyit.app.aspect">

expression="org.aspectj.lang.annotation.Aspect" />

二 切面类

package org.crazyit.app.aspect;

import org.aspectj.lang.annotation.*;

import org.aspectj.lang.*;

@Aspect

public class AccessArgAspect

{

// 下面的args(arg0,arg1)会限制目标方法必须有2个形参

@AfterReturning(returning="rvt" , pointcut=

"execution(* org.crazyit.app.service.impl.*.*(..)) && args(arg0,arg1)")

// 此处指定arg0、arg1为String类型

// 则args(arg0,arg1)还要求目标方法的两个形参都是String类型

public void access(Object rvt, String arg0 , String arg1)

{

System.out.println("调用目标方法第1个参数为:" + arg0);

System.out.println("调用目标方法第2个参数为:" + arg1);

System.out.println("获取目标方法返回值:" + rvt);

System.out.println("模拟记录日志功能...");

}

}

三 接口

Hello

package org.crazyit.app.service;

public interface Hello {

// 定义一个简单方法,模拟应用中的业务逻辑方法

void foo();

// 定义一个addUser()方法,模拟应用中的添加用户的方法

int addUser(String name, String pass);

}

World

package org.crazyit.app.service;

public interface World {

// 定义一个简单方法,模拟应用中的业务逻辑方法

public void bar();

}

四 实现类

HelloImpl

package org.crazyit.app.service.impl;

import org.springframework.stereotype.Component;

import org.crazyit.app.service.*;

@Component("hello")

public class HelloImpl implements Hello {

// 定义一个简单方法,模拟应用中的业务逻辑方法

public void foo() {

System.out.println("执行Hello组件的foo()方法");

}

// 定义一个addUser()方法,模拟应用中的添加用户的方法

public int addUser(String name, String pass) {

System.out.println("执行Hello组件的addUser添加用户:" + name);

return 20;

}

}

WorldImpl

package org.crazyit.app.service.impl;

import org.springframework.stereotype.Component;

import org.crazyit.app.service.*;

@Component("world")

public class WorldImpl implements World {

// 定义一个简单方法,模拟应用中的业务逻辑方法

public void bar() {

System.out.println("执行World组件的bar()方法");

}

}

五 测试类

package lee;

import org.springframework.context.*;

import org.springframework.context.support.*;

import org.crazyit.app.service.*;

public class BeanTest

{

public static void main(String[] args)

{

// 创建Spring容器

ApplicationContext ctx = new

ClassPathXmlApplicationContext("beans.xml");

Hello hello = ctx.getBean("hello" , Hello.class);

hello.foo();

hello.addUser("孙悟空" , "7788");

World world = ctx.getBean("world" , World.class);

world.bar();

}

}

六 测试结果

执行Hello组件的foo()方法

执行Hello组件的addUser添加用户:孙悟空

调用目标方法第1个参数为:孙悟空

调用目标方法第2个参数为:7788

获取目标方法返回值:20

模拟记录日志功能...

执行World组件的bar()方法

希望本文所述对大家java程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然可以,下面是一个简单的Spring AOP项目的代码示例: 首先,创建一个接口 `UserService`,定义一些用户相关的操作方法: ```java public interface UserService { void addUser(String username); void deleteUser(String username); } ``` 然后,创建一个实现该接口的类 `UserServiceImpl`: ```java public class UserServiceImpl implements UserService { @Override public void addUser(String username) { System.out.println("Adding user: " + username); } @Override public void deleteUser(String username) { System.out.println("Deleting user: " + username); } } ``` 接着,创建一个切面类 `LoggingAspect`,用于定义切面逻辑: ```java @Aspect public class LoggingAspect { @Before("execution(* UserService.*(..))") public void beforeMethod(JoinPoint joinPoint) { String methodName = joinPoint.getSignature().getName(); System.out.println("Before method: " + methodName); } @After("execution(* UserService.*(..))") public void afterMethod(JoinPoint joinPoint) { String methodName = joinPoint.getSignature().getName(); System.out.println("After method: " + methodName); } } ``` 最后,编写一个配置类 `AppConfig`,配置Spring容器和AOP: ```java @Configuration @EnableAspectJAutoProxy @ComponentScan("com.example") public class AppConfig { @Bean public UserService userService() { return new UserServiceImpl(); } @Bean public LoggingAspect loggingAspect() { return new LoggingAspect(); } } ``` 现在,你可以创建一个启动类 `MainApp` 来运行你的应用: ```java public class MainApp { public static void main(String[] args) { AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(AppConfig.class); UserService userService = context.getBean(UserService.class); userService.addUser("John"); userService.deleteUser("Jane"); context.close(); } } ``` 在上述示例,`LoggingAspect` 切面类使用了 `@Before` 和 `@After` 注解,分别在目标方法执行前和执行后执行切面逻辑。通过 `execution(* UserService.*(..))` 定义了切点表达式,表示匹配 `UserService` 接口的所有方法。 当你运行 `MainApp` 类时,你将会看到输出的日志信息,证明切面逻辑生效。 这只是一个简单的示例,你可以根据实际需求来定义更复杂的切面逻辑和切点表达式。希望对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值