spring--AOP--权限---demo1---bai
2017-01-12 11:14
267 查看
AOP权限DEMO1: 实体类: package com.etc.entity; import org.aspectj.lang.annotation.Pointcut; public class User implements IUser { public static int NORMAL = 1;//普通用户角色 public static int ADMIN = 2; //管理员角色 private int role; //所属的角色 public int getRole() { return role; } public void setRole(int role) { this.role = role; } public void login() { System.out.println("执行登录了!"); } public void reg() { System.out.println("执行注册了!"); //throw new RuntimeException("注册过程发生异常!"); } } ================================================================ 实体类需实现的接口: package com.etc.entity; //定义用户接口 public interface IUser { void login(); //登录 void reg(); //注册 } ================================================================= 通知类: package com.etc.advice; import java.util.Calendar; import org.aspectj.lang.ProceedingJoinPoint; import com.etc.entity.User; //实现权限校验的通知.规定周三不能登录系统 public class PrivilegeAdvice { public void around(ProceedingJoinPoint point) throws Throwable { //获得该通知被织入的目标对象 User u = (User) point.getTarget(); //1 今天是星期几? Calendar c = Calendar.getInstance(); int day = c.get(Calendar.DAY_OF_WEEK); if((day-1)==5&&u.getRole()==User.ADMIN) { System.out.println("周三普通用户不能登录本系统!"); return; } point.proceed();//允许代码继续往前 } } ================================================================= 配置文件: <?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:p="http://www.springframework.org/schema/p" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd"> <!-- 定义1个业务类对象 --> <bean id="user" class="com.etc.entity.User"> <property name="role" value="2"></property> </bean> <!-- 定义1个通知类对象 --> <bean id="myadv2" class="com.etc.advice.PrivilegeAdvice"> </bean> <aop:config> <!-- 配置切点的集合、即切线 --> <aop:pointcut expression="execution(* com.etc.entity.User.*(..))" id="mypc"/> <!-- 配置切入的方向 ,即切面--> <aop:aspect ref="myadv2"> <!-- 前置通知 --> <aop:before method="around" pointcut-ref="mypc"/> </aop:aspect> </aop:config> </beans> =============================================== 测试类: package com.etc.test; import org.springframework.beans.factory.BeanFactory; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.etc.entity.IUser; public class Test { public static void main(String[] args) { BeanFactory fac = new ClassPathXmlApplicationContext("applicationContext.xml"); IUser u = (IUser) fac.getBean("user"); //执行业务方法 u.login(); System.out.println("====="); try { u.reg(); } catch (Exception e) { } } } =====================================================================
相关文章推荐
- spring--AOP--日志---demo1---bai
- Spring-AOP(权限管理Demo)
- 利用Spring aop 进行权限管理
- 使用Spring 的 AOP 实现权限管理
- Spring AOP 权限
- 基于SSH2增删改查_控制层Action_Spring Aop权限控制基本实现(6)
- 基于 Annotation 拦截的 Spring AOP 权限验证方法
- 利用spring AOP管理权限[简单实例]
- SSH框架系列:Spring AOP应用记录日志Demo
- 利用spring AOP管理权限
- 运用Spring AOP验证用户权限实例
- 用spring Aop 做的管理权限(简单实例)
- Spring AOP 之 AfterAdviceDemo
- Spring AOP 之 IntroductionDemo
- Spring AOP 之 DelegatingIntroductionDemo
- Spring Aop 权限
- SpringAOP实现的用户权限管理【修改了别人的代码,感谢原作者!】
- Spring AOP 之 ControlFlowDemo
- Spring AOP 之 ThrowAdviceDemo2
- Spring 使用Aop 做切面日志,和权限。