利用spring AOP管理权限[简单实例]

Spring AOP 权限管理示例
本文介绍了一个使用 Spring AOP 实现的简单权限管理系统。通过定义用户角色及功能接口,配合自定义拦截器,实现了不同用户级别的权限控制。具体展示了如何针对未注册用户、普通用户和管理员设置不同的操作权限。

http://lighter.iteye.com/blog/42673

这一排在复习 spring的一些知识点,顺便写一下博客,下面看一下利用 spring AOP做的管理权限简单实例;
首先定义一个用户:
Java代码 复制代码
  1. publicclassUser{
  2. privateStringusername;
  3. publicStringgetUsername(){
  4. returnusername;
  5. }
  6. publicvoidsetUsername(Stringusername){
  7. this.username=username;
  8. }
  9. }
用户有三种人:未注册用户,注册用户,与管理员
注册用户可以可以发表,回复帖子
管理员除了可以发表,回复帖子,还可以删除帖子!
下面定义TestCommunity接口:
Java代码 复制代码
  1. publicinterfaceTestCommunity{
  2. publicvoidanswerTopic();
  3. publicvoiddeleteTopic();
  4. }
实现上面接口的TestCommunityImpl类:
Java代码 复制代码
  1. publicclassTestCommunityImplimplementsTestCommunity{
  2. //注册用户与管理员拥有的功能
  3. publicvoidanswerTopic(){
  4. System.out.println("可以发表,回复帖子");
  5. }
  6. //管理员拥有的功能
  7. publicvoiddeleteTopic(){
  8. System.out.println("可以删除帖子!");
  9. }
  10. }
下一步,建立一下依赖注入的实现类TestResultImpl:
Java代码 复制代码
  1. publicclassTestResultImpl{
  2. privateTestCommunitytest;
  3. publicvoidsetTest(TestCommunitytest){
  4. this.test=test;
  5. }
  6. publicvoidanswerTopic()
  7. {
  8. test.answerTopic();
  9. }
  10. publicvoiddeleteTopic()
  11. {
  12. test.deleteTopic();
  13. }
  14. }


接下来,就是最重要的一个类,拦截器,Around处理类型的,类TestAuthorityInterceptor:
Java代码 复制代码
  1. importorg.aopalliance.intercept.MethodInterceptor;
  2. importorg.aopalliance.intercept.MethodInvocation;
  3. //创建Around处理应该实现MethodInterceptor接口
  4. publicclassTestAuthorityInterceptorimplementsMethodInterceptor{
  5. privateUseruser;
  6. publicUsergetUser(){
  7. returnuser;
  8. }
  9. publicvoidsetUser(Useruser){
  10. this.user=user;
  11. }
  12. //invoke方法返回调用的结果
  13. publicObjectinvoke(MethodInvocationinvocation)throwsThrowable{
  14. StringmethodName=invocation.getMethod().getName();
  15. if(user.getUsername().equals("unRegistedUser")){
  16. System.out.println("你的身份是未注册用户,没有权限回复,删除帖子!");
  17. returnnull;
  18. }
  19. if((user.getUsername().equals("user"))
  20. &&(methodName.equals("deleteTopic"))){
  21. System.out.println("你的身份是注册用户,没有权限删除帖子");
  22. returnnull;
  23. }
  24. //proceed()方法对连接点的整个拦截器链起作用,拦截器链中的每个拦截器都执行该方法,并返回它的返回值
  25. returninvocation.proceed();
  26. }
  27. }
配置文件:
Java代码 复制代码
  1. <?xmlversion="1.0"encoding="UTF-8"?>
  2. <!DOCTYPEbeansPUBLIC"-//SPRING//DTDBEAN//EN""http://www.springframework.org/dtd/spring-beans.dtd">
  3. <beans>
  4. <beanid="authTarget"class="org.test.lighter.TestCommunityImpl"/>
  5. <!--其中的username可以写为admin,user,和unRegistedUser-->
  6. <beanid="user"class="org.test.lighter.User">
  7. <propertyname="username"value="user"/>
  8. </bean>
  9. <!--配置拦截器-->
  10. <beanid="TestAuthorityInterceptor"
  11. class="org.test.lighter.TestAuthorityInterceptor">
  12. <propertyname="user"ref="user"/>
  13. </bean>
  14. <!--配置代理工厂bean-->
  15. <beanid="service"
  16. class="org.springframework.aop.framework.ProxyFactoryBean">
  17. <propertyname="proxyInterfaces">
  18. <value>org.test.lighter.TestCommunity</value>
  19. </property>
  20. <propertyname="target"ref="authTarget"/>
  21. <propertyname="interceptorNames">
  22. <list>
  23. <value>TestAuthorityInterceptor</value>
  24. </list>
  25. </property>
  26. </bean>
  27. <beanid="testResult"class="org.test.lighter.TestResultImpl">
  28. <propertyname="test"ref="service"/>
  29. </bean>
  30. </beans>
再写一个执行文件BeanTest:
Java代码 复制代码
  1. importorg.springframework.context.ApplicationContext;
  2. importorg.springframework.context.support.FileSystemXmlApplicationContext;
  3. publicclassBeanTest{
  4. publicstaticvoidmain(String[]args)throwsException
  5. {
  6. ApplicationContextctx=newFileSystemXmlApplicationContext("src/bean.xml");
  7. TestResultImpltest=(TestResultImpl)ctx.getBean("testResult");
  8. test.answerTopic();
  9. test.deleteTopic();
  10. }
  11. }
执行结果:大家猜一下啦
Java代码 复制代码
  1. 1、如果是管理员,打印出:
  2. 可以发表,回复帖子
  3. 可以删除帖子!
  4. 2、如果是注册用户:
  5. 可以发表,回复帖子
  6. 你的身份是注册用户,没有权限删除帖子
  7. 3、未注册用户:
  8. 你的身份是未注册用户,没有权限回复,删除帖子!
 
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值