`
meiowei
  • 浏览: 147754 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

利用spring AOP管理权限

阅读更多
利用spring AOP做的管理权限简单实例;
首先定义一个用户:
Java代码
public class User {  
    private String username;  
 
    public String getUsername() {  
        return username;  
    }  
    public void setUsername(String username) {  
        this.username = username;  
    }  


public class User {
private String username;

public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
}
用户有三种人:未注册用户,注册用户,与管理员
注册用户可以可以发表,回复帖子
管理员除了可以发表,回复帖子,还可以删除帖子!
下面定义TestCommunity接口:
Java代码
public interface TestCommunity {  
  public void answerTopic();  
  public void deleteTopic();  


public interface TestCommunity {
  public void answerTopic();
  public void deleteTopic();
}

实现上面接口的TestCommunityImpl类:
Java代码
public class TestCommunityImpl implements TestCommunity {  
    //注册用户与管理员拥有的功能  
    public void answerTopic() {  
        System.out.println("可以发表,回复帖子");  
    }  
    //管理员拥有的功能  
    public void deleteTopic() {  
        System.out.println("可以删除帖子!");  
    }  


public class TestCommunityImpl implements TestCommunity {
//注册用户与管理员拥有的功能
public void answerTopic() {
System.out.println("可以发表,回复帖子");
}
//管理员拥有的功能
public void deleteTopic() {
System.out.println("可以删除帖子!");
}
}

下一步,建立一下依赖注入的实现类TestResultImpl:
Java代码
public class TestResultImpl {  
    private TestCommunity test;  
 
    public void setTest(TestCommunity test) {  
        this.test = test;  
    }     
     public void answerTopic()  
     {  
         test.answerTopic();  
     }  
      public void deleteTopic()  
      {  
          test.deleteTopic();  
      }  


public class TestResultImpl {
private TestCommunity test;

public void setTest(TestCommunity test) {
this.test = test;
}
public void answerTopic()
{
test.answerTopic();
}
  public void deleteTopic()
  {
  test.deleteTopic();
  }
}

接下来,就是最重要的一个类,拦截器,Around处理类型的,类TestAuthorityInterceptor:
Java代码
import org.aopalliance.intercept.MethodInterceptor;  
import org.aopalliance.intercept.MethodInvocation;  
 
//创建Around处理应该实现MethodInterceptor接口  
public class TestAuthorityInterceptor implements MethodInterceptor {  
    private User user;  
 
    public User getUser() {  
        return user;  
    }  
    public void setUser(User user) {  
        this.user = user;  
    }  
 
    // invoke方法返回调用的结果  
    public Object invoke(MethodInvocation invocation) throws Throwable {  
        String methodName = invocation.getMethod().getName();  
 
        if (user.getUsername().equals("unRegistedUser")) {  
            System.out.println("你的身份是未注册用户,没有权限回复,删除帖子!");  
            return null;  
        }  
        if ((user.getUsername().equals("user"))  
                && (methodName.equals("deleteTopic"))) {  
            System.out.println("你的身份是注册用户,没有权限删除帖子");  
            return null;  
        }  
        // proceed()方法对连接点的整个拦截器链起作用,拦截器链中的每个拦截器都执行该方法,并返回它的返回值  
        return invocation.proceed();  
    }  
 


import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;

//创建Around处理应该实现MethodInterceptor接口
public class TestAuthorityInterceptor implements MethodInterceptor {
private User user;

public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}

// invoke方法返回调用的结果
public Object invoke(MethodInvocation invocation) throws Throwable {
String methodName = invocation.getMethod().getName();

if (user.getUsername().equals("unRegistedUser")) {
System.out.println("你的身份是未注册用户,没有权限回复,删除帖子!");
return null;
}
if ((user.getUsername().equals("user"))
&& (methodName.equals("deleteTopic"))) {
System.out.println("你的身份是注册用户,没有权限删除帖子");
return null;
}
// proceed()方法对连接点的整个拦截器链起作用,拦截器链中的每个拦截器都执行该方法,并返回它的返回值
return invocation.proceed();
}

}


配置文件:
Java代码
<?xml version="1.0" encoding="UTF-8"?>  
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">  
<beans>  
    <bean id="authTarget" class="org.test.lighter.TestCommunityImpl" />  
 
    <!-- 其中的username可以写为admin,user,和unRegistedUser -->  
    <bean id="user" class="org.test.lighter.User">  
        <property name="username" value="user" />  
    </bean>  
 
    <!-- 配置拦截器 -->  
    <bean id="TestAuthorityInterceptor" 
        class="org.test.lighter.TestAuthorityInterceptor">  
        <property name="user" ref="user" />  
    </bean>  
 
    <!-- 配置代理工厂bean -->  
    <bean id="service" 
        class="org.springframework.aop.framework.ProxyFactoryBean">  
        <property name="proxyInterfaces">  
            <value>org.test.lighter.TestCommunity</value>  
        </property>  
        <property name="target" ref="authTarget"/>  
        <property name="interceptorNames">  
            <list>  
                <value>TestAuthorityInterceptor</value>  
            </list>  
        </property>  
    </bean>  
 
    <bean id="testResult" class="org.test.lighter.TestResultImpl">  
        <property name="test" ref="service" />  
    </bean>  
</beans> 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<bean id="authTarget" class="org.test.lighter.TestCommunityImpl" />

<!-- 其中的username可以写为admin,user,和unRegistedUser -->
<bean id="user" class="org.test.lighter.User">
<property name="username" value="user" />
</bean>

<!-- 配置拦截器 -->
<bean id="TestAuthorityInterceptor"
class="org.test.lighter.TestAuthorityInterceptor">
<property name="user" ref="user" />
</bean>

<!-- 配置代理工厂bean -->
<bean id="service"
class="org.springframework.aop.framework.ProxyFactoryBean">
<property name="proxyInterfaces">
<value>org.test.lighter.TestCommunity</value>
</property>
<property name="target" ref="authTarget"/>
<property name="interceptorNames">
<list>
<value>TestAuthorityInterceptor</value>
</list>
</property>
</bean>

<bean id="testResult" class="org.test.lighter.TestResultImpl">
<property name="test" ref="service" />
</bean>
</beans>

再写一个执行文件BeanTest:
Java代码
import org.springframework.context.ApplicationContext;  
import org.springframework.context.support.FileSystemXmlApplicationContext;  
 
public class BeanTest {  
  public static void main(String[] args) throws Exception  
  {  
      ApplicationContext ctx = new FileSystemXmlApplicationContext("src/bean.xml");  
      TestResultImpl test = (TestResultImpl)ctx.getBean("testResult");  
      test.answerTopic();  
      test.deleteTopic();  
  }  


import org.springframework.context.ApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;

public class BeanTest {
  public static void main(String[] args) throws Exception
  {
  ApplicationContext ctx = new FileSystemXmlApplicationContext("src/bean.xml");
  TestResultImpl test = (TestResultImpl)ctx.getBean("testResult");
  test.answerTopic();
  test.deleteTopic();
  }
}

执行结果:大家猜一下啦
Java代码
1、如果是管理员,打印出:  
可以发表,回复帖子  
可以删除帖子!  
 
2、如果是注册用户:  
可以发表,回复帖子  
你的身份是注册用户,没有权限删除帖子  
 
3、未注册用户:  
你的身份是未注册用户,没有权限回复,删除帖子!
分享到:
评论

相关推荐

    使用SpringAop使用Oracle数据权限控制

    通过以上步骤,我们可以利用Spring AOP的强大功能,结合Oracle的权限体系,实现灵活且高效的数据权限控制。这种方法既保持了业务逻辑的清晰,又确保了数据的安全性。同时,由于Spring AOP的切面是解耦的,所以这种...

    spring aop 实现权限的简单示例

    在本示例中,我们将深入探讨如何利用Spring AOP实现简单的权限验证。 首先,AOP的核心概念是切面(Aspect),它封装了横切关注点,比如日志、事务管理、权限验证等。在Spring AOP中,切面通过通知(Advice)来定义...

    Spring AOP实现机制

    **Spring AOP 实现机制详解** Spring AOP(面向切面编程)是Spring框架的核心特性之一,它允许程序员在不修改源代码的...通过深入理解Spring AOP的实现机制,我们可以更好地利用这一强大的工具,优化我们的应用程序。

    spring-aop-jar

    Spring AOP模块提供了实现AOP规范的功能,它允许开发者定义“切面”来封装系统中的横切关注点,如日志、事务管理等。该jar文件包含了Spring AOP的核心类和接口,如`org.springframework.aop.*`包下的`...

    spring aop

    在本项目中,你将看到如何在Maven和Spring框架下构建一个Web应用,并利用Spring AOP实现具体的业务逻辑。 1. **Maven集成Spring AOP** Maven是一个项目管理工具,通过依赖管理和项目构建,使得构建、测试和部署变...

    Spring AOP 权限

    本篇文章将深入探讨如何利用Spring AOP来实现权限管理,以及相关的知识点。 首先,权限管理是系统安全的关键组成部分,它确保只有具有适当权限的用户才能访问特定的资源或执行特定的操作。在Spring AOP中,我们可以...

    spring AOP的运用

    Spring AOP,全称Aspect-Oriented Programming(面向切面编程),是Spring框架的重要组成部分,它为Java应用程序提供了声明式的企业级服务,如事务管理、日志记录等。AOP的核心概念是切面(Aspect)和通知(Advice)...

    spring aop 依赖jar

    总的来说,理解并正确配置Spring AOP的依赖,以及熟练掌握切面、通知和切入点的概念,对于有效利用Spring进行面向切面编程至关重要。通过这些技术,开发者可以将关注点分离,提高代码的可维护性和可复用性。

    SpringAOP.rar_springAOP

    其中,Spring AOP(Aspect Oriented Programming,面向切面编程)是Spring框架的重要组成部分,它为开发者提供了在不侵入业务代码的情况下,进行日志记录、性能监控、事务管理等横切关注点的能力。本文将深入探讨...

    spring aop 附带测试实例

    在提供的压缩包文件"springAOP"中,可能包含了以下内容: - **切面类(Aspect Class)**:包含切点和通知的Java类,可能使用了`@Aspect`注解。 - **目标类(Target Class)**:被AOP代理的对象,通常包含业务逻辑。...

    spring AOP注解的应用1

    本篇主要探讨的是如何利用Spring AOP的注解来实现这些功能,包括前置通知、后置通知、返回通知和异常通知。 ### 前置通知(Before通知) 前置通知在目标方法执行之前运行。在Spring AOP中,我们使用`@Before`注解...

    spring之AOP(动态代理)

    在Spring框架中,AOP(面向切面编程)是一种强大的设计模式,它允许开发者将关注点分离,将横切关注点(如日志、事务管理、权限检查等)与核心业务逻辑解耦。AOP的核心概念是切面、通知、连接点、切入点和织入。在...

    Spring 2.5 AOP 例子

    Spring 2.5 AOP(面向切面编程)...综上所述,Spring 2.5 AOP例子展示了如何利用类扫描和XML配置实现面向切面编程。通过理解这些概念和实践,我们可以更高效地管理和维护我们的应用程序,使其更具可扩展性和可维护性。

    spring-aop.jar

    在实际应用中,我们可以利用Spring AOP进行日志记录、事务管理、权限控制等。例如,通过定义一个切面类,包含前置通知记录方法调用日志,后置通知处理事务提交或回滚,以及异常通知进行异常处理。 四、实战案例 ...

    spring Aop文档

    ### Spring AOP 文档知识点详解 #### 一、Spring AOP 概述 Spring AOP(面向切面编程)是...通过对Spring AOP的基本概念、配置方式以及源码层面的理解,我们可以更好地利用这一强大的工具来优化我们的应用程序。

    Spring AOP总结

    在实际开发中,我们可以利用Spring AOP提供的注解,如`@Aspect`、`@Before`、`@After`等,来方便地定义和使用切面。同时,通过`@Pointcut`定义通用的切入点表达式,可以提高代码的复用性。 总之,Spring AOP提供了...

    Spring3.0.5扩展支持AOP获取HttpServletResponse

    切面是模块化的关注点,如日志记录、事务管理或权限控制。通知定义了在特定连接点上执行的行为,而连接点是程序执行的特定点,如方法调用。切入点是匹配连接点的表达式,决定了通知何时执行。织入是将切面应用到目标...

    JDK动态代理 spring aop 的原理

    Spring AOP(面向切面编程)则是一种流行的应用框架,它利用动态代理来实现对业务代码的切面增强,如日志、事务管理等。现在让我们深入探讨JDK动态代理和Spring AOP的原理。 首先,JDK动态代理基于Java的反射机制,...

    spring AOP 切面日志 分层打日志

    在Spring框架中,AOP(面向切面编程)是一种强大的工具,它允许我们在不修改源代码的情况下,对程序进行横向关注点的插入,比如日志记录、事务管理、权限检查等。在这里,我们重点关注如何利用Spring AOP实现分层...

    使用Spring配置文件实现AOP

    在Spring框架中,面向切面编程(Aspect Oriented Programming,简称AOP)是一种强大的设计模式,它允许我们...通过深入理解和实践,我们可以更好地利用Spring AOP来优化我们的应用程序,提高代码的可读性和可维护性。

Global site tag (gtag.js) - Google Analytics