Spring AOP_学习记录_04

1.After advice Types

  • org.zcs.springAop - AopMain.java
package org.zcs.springAop;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.zcs.springAop.service.ShapeService;

public class AopMain {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		ApplicationContext ctx = new ClassPathXmlApplicationContext("spring.xml");
		ShapeService shapeservice = ctx.getBean("shapeService", ShapeService.class);
		shapeservice.getCircle().setName (" Dan- Xiang - Jian - Tou");
 
	}
}

  • org.zcs.springAop.aspect-LoggingAspect.java
package org.zcs.springAop.aspect;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.zcs.springAop.model.Circle;

@Aspect
public class LoggingAspect {
	//@Before("execution(	public String org.zcs.springAop.model.Circle.getName())")
	@Before("allCircleMethods()")
	public void LoggingAdvice(JoinPoint joinPoint) {
	 
	}
	
	@AfterReturning(pointcut="args(name)", returning="returnString") 
	public void getMethodsarguments(String name, String returnString) {
		System.out.println("A method that takes string argument be called . The Value is : " + name +",The return  String is :" + returnString);
	}
	
	@AfterThrowing(pointcut="args(name)", throwing = "ex")
	public void exceptionAdvice(String name, RuntimeException ex) {
		System.out.println("An execption has been thrown." + ex);
	}
	@Pointcut("execution(	public *  get*())")
	public void allGetters() {
	}
	
	@Pointcut("within(org.zcs.springAop.model.Circle)")
	public void allCircleMethods() {}
	
}

  • org.zcs.springAop.model - Circle.java
package org.zcs.springAop.model;

public class Circle {
	private String name;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
		System.out.println(" Circle's setter be called." );
		throw(new RuntimeException());
	}
	public String setNameReturn(String name) {
		this.name = name;
		System.out.println(" Circle's setter be called." );
		return name;
	}
}

  • org.zcs.springAop.model-Triangle.java
package org.zcs.springAop.model;

public class Triangle {
	private String name;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
	
}

  • org.zcs.springAop.serivce-ShapeService.java
package org.zcs.springAop.service;

import org.zcs.springAop.model.Circle;
import org.zcs.springAop.model.Triangle;

public class ShapeService {
	private Circle circle;
	private Triangle triangle;
	public Circle getCircle() {
		return circle;
	}
	public void setCircle(Circle circle) {
		this.circle = circle;
	}
	public Triangle getTriangle() {
		return triangle;
	}
	public void setTriangle(Triangle triangle) {
		this.triangle = triangle;
	}
	
}

  • spring.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd">
       <aop:aspectj-autoproxy></aop:aspectj-autoproxy>
       <bean name="triangle" class = "org.zcs.springAop.model.Triangle">
       		<property name="name" value = "Triangle name"></property>
       </bean>
       <bean name = "circle" class = "org.zcs.springAop.model.Circle">
       		
       </bean>
       <bean name="shapeService" class="org.zcs.springAop.service.ShapeService" autowire = "byName"></bean>
 		<bean name= "loggingAspect" class = "org.zcs.springAop.aspect.LoggingAspect"></bean>
 </beans>

2.学习记录

  • 学习aspect中的注释: A f t e r After After与before相同,只不过它是出现在制定的类的后面。
  • 学习如何在出现一个抛出异常时,进行日志标志
  • 学习了在after和before中使用两个参数的使用。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值