Aspectj框架实战案例详解

本文实例讲述了Aspectj框架。分享给大家供大家参考,具体如下:

一 环境变量配置

CLASSPATH配置为:

.;d:\aspectj1.8\lib\aspectjrt.jar;D:\Program\Java\jdk1.8.0_162\lib\dt.jar;D:\Program\Java\jdk1.8.0_162\lib\tools.jar;

path要配置为:

d:\aspectj1.8\bin

二 代码

1 JavaBean

Hello.java

package org.crazyit.app.service;
public class 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;
  }
}

World.java

package org.crazyit.app.service;
public class World
{
  // 定义一个简单方法,模拟应用中的业务逻辑方法
  public void bar()
  {
    System.out.println("执行World组件的bar()方法");
  }
}

2 AOP

AuthAspect.java

package org.crazyit.app.aspect;
public aspect AuthAspect
{
  // 指定在执行org.crazyit.app.service包中任意类的、任意方法之前执行下面代码块
  // 第一个星号表示返回值不限;第二个星号表示类名不限;
  // 第三个星号表示方法名不限;圆括号中..代表任意个数、类型不限的形参
  before(): execution(* org.crazyit.app.service.*.*(..))
  {
    System.out.println("模拟进行权限检查...");
  }
}

LogAspect.java

package org.crazyit.app.aspect;
public aspect LogAspect
{
  // 定义一个PointCut,其名为logPointcut,
  // 该Pointcut代表了后面给出的切入点表达式,这样可复用该切入点表达式
  pointcut logPointcut()
    :execution(* org.crazyit.app.service.*.*(..));
  after():logPointcut()
  {
    System.out.println("模拟记录日志...");
  }
}

TxAspect.java

package org.crazyit.app.aspect;
public aspect TxAspect
{
  // 指定执行Hello.sayHello()方法时执行下面代码块
  Object around():call(* org.crazyit.app.service.*.*(..))
  {
    System.out.println("模拟开启事务...");
    // 回调原来的目标方法
    Object rvt = proceed();
    System.out.println("模拟结束事务...");
    return rvt;
  }
}

3 测试类

package lee;
import org.crazyit.app.service.Hello;
import org.crazyit.app.service.World;
public class AspectJTest
{
  public static void main(String[] args)
  {
    Hello hello = new Hello();
    hello.foo();
    hello.addUser("孙悟空" , "7788");
    World world = new World();
    world.bar();
  }
}

三 编译

G:\test\AspectJQs>ajc -d . *.java

四 编译后的结构

G:\test\AspectJQs>tree /f
卷 VirtualOS 的文件夹 PATH 列表
卷序列号为 8600-758F
G:.
│  AspectJTest.java
│  AuthAspect.java
│  Hello.java
│  LogAspect.java
│  TxAspect.java
│  World.java

├─lee
│      AspectJTest.class

└─org
    └─crazyit
        └─app
            ├─aspect
            │      AuthAspect.class
            │      LogAspect.class
            │      TxAspect.class
            │
            └─service
                    Hello.class
                    World.class

五 运行

G:\test\AspectJQs>java lee.AspectJTest
模拟开启事务...
模拟进行权限检查...
执行Hello组件的foo()方法
模拟记录日志...
模拟结束事务...
模拟开启事务...
模拟进行权限检查...
执行Hello组件的addUser添加用户:孙悟空
模拟记录日志...
模拟结束事务...
模拟开启事务...
模拟进行权限检查...
执行World组件的bar()方法
模拟记录日志...
模拟结束事务...

希望本文所述对大家基于Aspectj框架的java程序设计有所帮助。

(0)

相关推荐

  • AndroidStudio 配置 AspectJ 环境实现AOP的方法

    昨天看了一段android配置aspectj实现AOP的直播视频,就试着自己配置了一下,可能是因为我自己的AndroidStudio环境的问题,碰到了不少的坑(其实还是因为对gradle理解的不多),但总归是配置好了,就分享一下. 试了两种方式,不过项目下的build.gradle,没什么变化,直接看一下代码吧: build.gradle(项目下) buildscript { ext { //android appcompat支持库版本 androidSupportVersion = '26.1

  • 在Android项目中使用AspectJ的方法

    什么是AOP AOP是 Aspect Oriented Programming 的缩写,即面向切面编程,和平常遇到的面向对象OOP编程不一样的是,OOP是将功能模块化对象化,AOP是针对同一类的问题统一化处理.例如做日志埋点,性能监控,动态权限控制等. AspectJ AspectJ实际上是对AOP编程的实践,目前还有很多的AOP实现,如ASMDex,但笔者选用的是AspectJ. 在Android项目中使用AspectJ 如果使用原生AspectJ在项目中配置会非常麻烦,在GitHub上有个开

  • Android AOP框架AspectJ使用详解

    前言 之前了解过android的AOP框架,用法主要用来打日志:现在有一个需求需要函数在新线程中执行,并且函数主体执行完之后,在UI线程返回结果.想到手写的话,每次都要new Thread的操作,比较麻烦:因此就尝试用注解的方法解决这个问题. AspectJ的使用核心就是它的编译器,它就做了一件事,将AspectJ的代码在编译期插入目标程序当中,运行时跟在其它地方没什么两样,因此要使用它最关键的就是使用它的编译器去编译代码ajc.ajc会构建目标程序与AspectJ代码的联系,在编译期将Aspe

  • 分析java 中AspectJ切面执行两次的原因

    分析java 中AspectJ切面执行两次的原因 背景 转眼之间,发现博客已经将近半年没更新了,甚是惭愧.话不多说,正如标题所言,最近在使用AspectJ的时候,发现拦截器(AOP切面)执行了两次了.我们知道,AspectJ是AOP的一种解决方案,本质上是通过代理类在目标方法执行通知(Advice),然后由代理类再去调用目标方法.所以,从这点讲,拦截器应该只会执行一次.但是在测试的时候发现拦截器执行了两次. 问题重现 既然问题已经明了,那么可以通过代码简单重现这个问题,从而更深层次分析到底是什么

  • 详解Spring Aop实例之AspectJ注解配置

    上篇<Spring Aop实例之xml配置>中,讲解了xml配置方式,今天来说说AspectJ注解方式去配置spring aop. 依旧采用的jdk代理,接口和实现类代码请参考上篇博文.主要是将Aspect类分享一下: package com.tgb.aop; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.Aft

  • AspectJ的基本用法

    AOP虽然是方法论,但就好像OOP中的Java一样,一些先行者也开发了一套语言来支持AOP.目前用得比较火的就是AspectJ了,它是一种几乎和Java完全一样的语言,而且完全兼容Java(AspectJ应该就是一种扩展Java,但它不是像Groovy[1]那样的拓展.).当然,除了使用AspectJ特殊的语言外,AspectJ还支持原生的Java,只要加上对应的AspectJ注解就好.所以,使用AspectJ有两种方法: 完全使用AspectJ的语言.这语言一点也不难,和Java几乎一样,也能

  • java基于AspectJ(面向切面编程)编码示例分享

    一.基本概念 AspectJ是一种面向切面程序设计的基于Java 的实现.它向 Java 中加入了连接点(Join Point)这个新概念,其实它也只是现存的一个 Java概念的名称而已.它向 Java 语言中加入少许新结构:切点(pointcut).通知(Advice).类型间声明(Inter-type declaration)和方面(Aspect).切点和通知动态地影响程序流程,类型间声明则是静态的影响程序的类等级结构,而切面则是对所有这些新结构的封装. 基于切面.连接点.切点.通知的概念如

  • Android中使用AspectJ详解

    什么是AOP AOP是Aspect Oriented Programming的缩写,即『面向切面编程』.它和我们平时接触到的OOP都是编程的不同思想,OOP,即『面向对象编程』,它提倡的是将功能模块化,对象化,而AOP的思想,则不太一样,它提倡的是针对同一类问题的统一处理,当然,我们在实际编程过程中,不可能单纯的安装AOP或者OOP的思想来编程,很多时候,可能会混合多种编程思想,大家也不必要纠结该使用哪种思想,取百家之长,才是正道. 那么AOP这种编程思想有什么用呢,一般来说,主要用于不想侵入原

  • Spring Aop之AspectJ注解配置实现日志管理的方法

    最近项目要做一个日志功能,我用Spring Aop的注解方式来实现. 创建日志注解 package com.wyj.annotation; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lan

  • Spring用AspectJ开发AOP(基于Annotation)

    基于 Annotation 的声明式 在 Spring 中,尽管使用 XML 配置文件可以实现 AOP 开发,但是如果所有的相关的配置都集中在配置文件中,势必会导致 XML 配置文件过于臃肿,从而给维护和升级带来一定的困难. 为此,AspectJ 框架为 AOP 开发提供了另一种开发方式--基于 Annotation 的声明式.AspectJ 允许使用注解定义切面.切入点和增强处理,而 Spring 框架则可以识别并根据这些注解生成 AOP 代理. 关于 Annotation 注解的介绍如表 1

  • 详解在Spring中如何使用AspectJ来实现AOP

    AspectJ 是通过注解来描述切点与增强的. 1 开发环境要求 因为要使用注解,所以请确保使用的 Java5.0 及以上版本. 引入 AspectJ 相关类库: <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjrt</artifactId> <version>${aspectj.version}</version> </dependenc

  • Spring使用AspectJ注解和XML配置实现AOP

    本文演示的是Spring中使用AspectJ注解和XML配置两种方式实现AOP 下面是使用AspectJ注解实现AOP的Java Project 首先是位于classpath下的applicationContext.xml文件 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmln

随机推荐