`
digyso
  • 浏览: 139136 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

利用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. 你的身份是未注册用户,没有权限回复,删除帖子!
分享到:
评论

相关推荐

    aop权限管理实例

    aop权限管理实例真实项目完整实例,有完整代码和配置及说明,spring版本是2.5,有需要的可以下载。上传只为分享

    spring-boot示例项目

    该项目包含helloworld(快速入门)、web(ssh项目快速搭建)、aop(切面编程)、data-redis(redis缓存)、quartz(集群任务实现)、shiro(权限管理)、oauth2(四种认证模式)、shign(接口参数防篡改重放)、encoder(用户...

    Spring面试题

    4.容器提供了AOP技术,利用它很容易实现如权限拦截,运行期监控等功能 5.容器提供了众多的辅助类,能加快应用的开发 6.spring对于主流的应用框架提供了集成支持,如hibernate,JPA,Struts等 7.spring属于低侵入...

    基于java实现仿京东商城电商系统项目设计与实现源码分享

    依赖注入来管理各层,面向切面编程管理事务,日志和权限 MyBatis:持久层;访问数据库;基于jdbc的框架,主要用来操作数据库,并且将业务实体和数据表联系起来 1、Spring (1)基本概念 Spring是一个开源开发框架...

    基于java实现仿京东商城电商系统项目设计与实现源码

    依赖注入来管理各层,面向切面编程管理事务,日志和权限 MyBatis:持久层;访问数据库;基于jdbc的框架,主要用来操作数据库,并且将业务实体和数据表联系起来 1、Spring (1)基本概念 Spring是一个开源开发框架...

    基于java实现大学生求职就业网项目设计源码分享

    依赖注入来管理各层,面向切面编程管理事务,日志和权限 MyBatis:持久层;访问数据库;基于jdbc的框架,主要用来操作数据库,并且将业务实体和数据表联系起来 1、Spring (1)基本概念 Spring是一个开源开发框架...

    基于java实现大学生求职就业网项目设计源码

    依赖注入来管理各层,面向切面编程管理事务,日志和权限 MyBatis:持久层;访问数据库;基于jdbc的框架,主要用来操作数据库,并且将业务实体和数据表联系起来 1、Spring (1)基本概念 Spring是一个开源开发框架...

    jsp论坛管理系统+sqlserver

    系统架构是现在主流的SSH架构模式,使用了Spring的Ioc来实现组件之间的依赖关系注入,使用Spring的AOP编程实现权限控制、日志服务等与业务无关的系统服务,以及Struts的action、form、Jsp页面的结构架构的整合如下:...

    使用JIVE的代理模式来扩展struts+Spring+Hibernate的web框架

    管理员对系统模块的操作权限认证,有主要有三种方法: 1.在每个需要认证的模块前面插入一段验证码. 2.使用AOP或拦截器. 3.使用代理设计模式. 第一种方法,太笨. 第二种方法,在struts中不易实现,因为Strust的Action...

    J2EE应用开发详解

    325 18.4.2 配置数据库连接池 327 18.5 HQL简介 328 18.6 小结 330 第19章 权限管理系统(Struts+Spring+Hiberante+Ajax) 331 19.1 需求分析 331 19.2 系统总体流程设计 331 19.3 系统设计 332 19.4 系统总体解析 ...

    基于jbpm与activiti的工作流平台技术架构介绍

    BPMX3提供了基于BPMN2标准的流程管理,包括流程版本变量,流程节点表单设置,表单的权限设置,流程任务通知,催办,代办,转化,并行会签、串行会签、补签,子流程,同步任务,多实例任务,人工任务、消息任务、邮件...

    Java源码 SpringMVC Mybatis Shiro Bootstrap Rest Webservice

    1. Springmvc + Mybatis集成、SpringSecurity权限控制、Spring AOP事务处理。 2. Wink Rest服务、Webservice服务:jaxws、CXF等 3. IO 流上传下载文件,多线程操作 4. 发送邮件,配置邮件服务器,发基于html、纯...

    asp.net知识库

    Coalesys PanelBar + R.a.d Treeview +Xml 构建的Asp.net 菜单和权限管理模块 突破屏蔽限制,自己的网站使劲弹新IE窗口 对页面SCROLLING的CSS不能生效原因 .Net 中IE使用WinForm控件的使用心得。 动态加载用户控件的...

    Java学习笔记-个人整理的

    {1.11}简单算法}{38}{section.1.11} {1.11.1}打乱算法}{38}{subsection.1.11.1} {1.11.2}排序算法}{38}{subsection.1.11.2} {1.11.2.1}选择排序}{38}{subsubsection.1.11.2.1} {1.11.2.2}冒泡排序}{39}{...

Global site tag (gtag.js) - Google Analytics