- 浏览: 501667 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
来这里学java:
...
实战篇:设计自己的Annotation -
yushui2000:
突然想到一种方法,就是1、2、2、3、4、5作为5个球(类似彩 ...
一道算法题目,值得一看 -
wst0350:
理解力
实战篇:设计自己的Annotation -
yingzhor:
楼下的,你看看代码不就知道怎么验证了吗?这不是放在sessio ...
利用servlet生成简单的验证码 -
ming_7755:
妙用Commons良药<三>
这一排在复习spring的一些知识点,顺便写一下博客,下面看一下利用spring AOP做的管理权限简单实例;
首先定义一个用户:
用户有三种人:未注册用户,注册用户,与管理员
注册用户可以可以发表,回复帖子
管理员除了可以发表,回复帖子,还可以删除帖子!
下面定义TestCommunity接口:
实现上面接口的TestCommunityImpl类:
下一步,建立一下依赖注入的实现类TestResultImpl:
接下来,就是最重要的一个类,拦截器,Around处理类型的,类TestAuthorityInterceptor:
配置文件:
再写一个执行文件BeanTest:
执行结果:大家猜一下啦
你要的是不是拦截器来控制URL路径的转发啊
给一个例子你看一下
配置文件:
刚刚出去一下回来就看到你的回复啦
好好努力啦,学点东西;学东西不在于多,在于熟练;
这一篇文章实现的功能太简陋啦,不过你也自己扩展一下啦,对你有一点点的帮忙就感觉欣慰啦
可能是有一点粗心写错了什么啦
ps:你们还没有放寒假吗?在学校?
我这边测试没有问题啊,源代码上传给你看一下
还有问题的话,我再看一下程序啦,或者有bug,
首先定义一个用户:
public class User { private String username; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } }
用户有三种人:未注册用户,注册用户,与管理员
注册用户可以可以发表,回复帖子
管理员除了可以发表,回复帖子,还可以删除帖子!
下面定义TestCommunity接口:
public interface TestCommunity { public void answerTopic(); public void deleteTopic(); }
实现上面接口的TestCommunityImpl类:
public class TestCommunityImpl implements TestCommunity { //注册用户与管理员拥有的功能 public void answerTopic() { System.out.println("可以发表,回复帖子"); } //管理员拥有的功能 public void deleteTopic() { System.out.println("可以删除帖子!"); } }
下一步,建立一下依赖注入的实现类TestResultImpl:
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:
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(); } }
配置文件:
<?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:
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(); } }
执行结果:大家猜一下啦
1、如果是管理员,打印出: 可以发表,回复帖子 可以删除帖子! 2、如果是注册用户: 可以发表,回复帖子 你的身份是注册用户,没有权限删除帖子 3、未注册用户: 你的身份是未注册用户,没有权限回复,删除帖子!
评论
16 楼
wangzhongjie
2007-06-11
简单实用
15 楼
diandidemeng
2007-02-26
- 1. <bean id="user" class="org.test.lighter.User">
2. <property name="username" value="user" />
3. </bean>
14 楼
tear
2007-02-01
thank you,lighter!
我不仅仅是想实现用户登陆的验证,我想实现这样的功能:
http://www.iteye.com/topic/51623?page=1
(要没熄灯了,例子下下来了还没来得及看)
我不仅仅是想实现用户登陆的验证,我想实现这样的功能:
http://www.iteye.com/topic/51623?page=1
(要没熄灯了,例子下下来了还没来得及看)
13 楼
lighter
2007-02-01
如果你用spring的MVC,把上面的ActionMapping替换掉
其实也可能通过写一个过滤器implements Filter来实现你的功能
还有一个简单的代码实例,可以看一下
其实也可能通过写一个过滤器implements Filter来实现你的功能
还有一个简单的代码实例,可以看一下
12 楼
lighter
2007-02-01
tear 写道
如果我不是对DAO里的method进行拦截,而是对这样的URL:http://localhost:8080/bookroom/listUser.htm(调用userController里的listUser方法,然后转发到listUser.jsp),那么该怎么用SPRING AOP进行拦截呢?
或者说因为该URL调用了Controller里的方法,所以如果要对该URL进行拦截那么等于去拦截Controller里的方法,又因为Controller里的方法其实又调用了DAO里的方法,所以归根结底我可不可以通过拦截DAO里的方法来最终实现URL的拦截?
(说的很乱,不知道能不能让人看明白 )
或者说因为该URL调用了Controller里的方法,所以如果要对该URL进行拦截那么等于去拦截Controller里的方法,又因为Controller里的方法其实又调用了DAO里的方法,所以归根结底我可不可以通过拦截DAO里的方法来最终实现URL的拦截?
(说的很乱,不知道能不能让人看明白 )
你要的是不是拦截器来控制URL路径的转发啊
给一个例子你看一下
import javax.servlet.http.HttpServletRequest; import org.aopalliance.intercept.MethodInterceptor; import org.aopalliance.intercept.MethodInvocation; import org.apache.struts.action.ActionMapping; /** * 这是一个拦截器,用来验证用户是否通过验证 * */ public class AuthorityInterceptor implements MethodInterceptor { public Object invoke(MethodInvocation invocation) throws Throwable { HttpServletRequest request = null; ActionMapping mapping = null; Object[] args = invocation.getArguments(); for (int i = 0 ; i < args.length ; i++ ) { if (args[i] instanceof HttpServletRequest) request = (HttpServletRequest)args[i]; if (args[i] instanceof ActionMapping) mapping = (ActionMapping)args[i]; } if ( request.getSession().getAttribute("adminname") != null) { return invocation.proceed(); } else { return mapping.findForward("login"); } } }
配置文件:
<bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator"> <property name="beanNames"> <list> <value>/vaiiduser</value> <value>/admin</value> <value>/phone</value> </list> </property> <property name="interceptorNames"> <list> <value>authorityInterceptor</value> </list> </property> </bean> <bean id="authorityInterceptor" class="org.mmc.utils.AuthorityInterceptor"/>
11 楼
tear
2007-02-01
对原文方法理解失误了
先去写写代码证实一下,还不大肯定
先去写写代码证实一下,还不大肯定
10 楼
tear
2007-02-01
如果我不是对DAO里的method进行拦截,而是对这样的URL:http://localhost:8080/bookroom/listUser.htm(调用userController里的listUser方法,然后转发到listUser.jsp),那么该怎么用SPRING AOP进行拦截呢?
或者说因为该URL调用了Controller里的方法,所以如果要对该URL进行拦截那么等于去拦截Controller里的方法,又因为Controller里的方法其实又调用了DAO里的方法,所以归根结底我可不可以通过拦截DAO里的方法来最终实现URL的拦截?
(说的很乱,不知道能不能让人看明白 )
或者说因为该URL调用了Controller里的方法,所以如果要对该URL进行拦截那么等于去拦截Controller里的方法,又因为Controller里的方法其实又调用了DAO里的方法,所以归根结底我可不可以通过拦截DAO里的方法来最终实现URL的拦截?
(说的很乱,不知道能不能让人看明白 )
9 楼
lighter
2007-01-29
tear 写道
也许是吧.不过前后一点没改,再换回去居然就能正确运行了.
26号就放假了,回家没有电脑,想在学校再学点什么再回去.很早就看到这篇AOP权限管理,现在有时间了,想把它应用到以前的一个东西上.希望回家之前能做好
26号就放假了,回家没有电脑,想在学校再学点什么再回去.很早就看到这篇AOP权限管理,现在有时间了,想把它应用到以前的一个东西上.希望回家之前能做好
刚刚出去一下回来就看到你的回复啦
好好努力啦,学点东西;学东西不在于多,在于熟练;
这一篇文章实现的功能太简陋啦,不过你也自己扩展一下啦,对你有一点点的帮忙就感觉欣慰啦
8 楼
tear
2007-01-29
也许是吧.不过前后一点没改,再换回去居然就能正确运行了.
26号就放假了,回家没有电脑,想在学校再学点什么再回去.很早就看到这篇AOP权限管理,现在有时间了,想把它应用到以前的一个东西上.希望回家之前能做好
26号就放假了,回家没有电脑,想在学校再学点什么再回去.很早就看到这篇AOP权限管理,现在有时间了,想把它应用到以前的一个东西上.希望回家之前能做好
7 楼
lighter
2007-01-29
tear 写道
下载下来替换之后运行成功!
然后回头再把我写的替换回去竟然也能正确运行了,可是刚才明明一直运行不正确的.
呵呵~不知道什么原因,好奇怪!
然后回头再把我写的替换回去竟然也能正确运行了,可是刚才明明一直运行不正确的.
呵呵~不知道什么原因,好奇怪!
可能是有一点粗心写错了什么啦
ps:你们还没有放寒假吗?在学校?
6 楼
tear
2007-01-29
下载下来替换之后运行成功!
然后回头再把我写的替换回去竟然也能正确运行了,可是刚才明明一直运行不正确的.
呵呵~不知道什么原因,好奇怪!
然后回头再把我写的替换回去竟然也能正确运行了,可是刚才明明一直运行不正确的.
呵呵~不知道什么原因,好奇怪!
5 楼
tear
2007-01-29
THANK YOU!
lighter
我这就去看看,有结果再回复.
lighter
我这就去看看,有结果再回复.
4 楼
lighter
2007-01-29
tear 写道
我照着写了一遍,但是不知道为什么无论是把username的value改成unRegisteduser还是admin,结果都是value="user"时的输出
<bean id="user" class="org.test.lighter.User"> <property name="username" value="user" /> </bean>
我这边测试没有问题啊,源代码上传给你看一下
还有问题的话,我再看一下程序啦,或者有bug,
3 楼
tear
2007-01-29
我照着写了一遍,但是不知道为什么无论是把username的value改成unRegisteduser还是admin,结果都是value="user"时的输出
<bean id="user" class="org.test.lighter.User"> <property name="username" value="user" /> </bean>
2 楼
jinlibing
2007-01-02
顶。。。
1 楼
lighter
2007-01-01
这一排写了比较多的复习笔记,都整理在自己的博客上...
发表评论
-
网站性能优化的34条准则
2009-03-02 22:02 1690引用Best Practices for Speeding U ... -
Oracle数据库体系结构小记
2007-10-27 16:43 2283现在从事银行软件开发,整天与Oracle数据库接触多一些,慢慢 ... -
心血来潮:重新温习一下C语言的指针
2007-10-25 20:58 1686近来几天白天有时候比较有空,所以就复习看看资料,这两天,有 ... -
SQLLOADER不装数情况分析
2007-10-16 17:51 2152其实这一篇文章最核心的东西都是项目组的忠哥写的,他已经飞往新疆 ... -
对于表被锁起的操作[Oracle]
2007-09-25 10:51 2219对于表被锁起的操作: 查询: SELECT A.OWNER ... -
Oracle索引失效问题小结
2007-09-24 22:43 10307今天在做刚上线的项目技术支持的时候,忠哥告诉我的如下的做法: ... -
javascript记录点滴
2007-01-21 12:36 27931、在javaScript中,Window是 ... -
今天编码日志小结
2007-01-19 00:46 22651、把POJO里的 注册时间 属性写成registerTim ... -
复习笔记:Timer和Quartz任务调度点滴
2006-12-31 21:06 5074[size=10]复习笔记:Timer和Quartz任务调度 ... -
复习笔记:关于Spring AOP的一些点滴
2006-12-31 11:03 3473Advice标签接口是所有处 ... -
复习笔记:利用spring进行简化测试
2006-12-30 16:52 8527[size=10] 下午复习了一点 ... -
请问对于实际的Web项目应该怎样进行TDD
2006-12-14 22:16 4695温柔一刀 写道lighter 写道温柔一刀 写道理解不到位的地 ... -
MOCK的几个概念
2006-12-14 13:01 2107以下三种概念通常都被称为mock 1、stub 这是一种其方 ... -
关于数据库的一些优化
2006-11-25 13:02 2107前两天,有家伙问了我一 ... -
最近一排看的书籍(java方面的)
2006-06-04 17:57 2398近来一排看的java书籍 1 ... -
大四了,想一想时间过得很快......
2006-08-26 11:08 20878月28号开学,还有两天的 ...
相关推荐
Spring的核心特性是控制反转(IOC)和面向切面编程(AOP)。它提供了一个全面的编程和配置模型,可以用于构建各种类型的Java应用程序,包括Web应用。 1. **Spring介绍** - **侵入式概念**:传统Java EE应用中,...
动力节点老杜Spring6配套笔记主要讲解了Spring框架的一些核心概念和最佳实践,特别是针对代码设计中的开闭原则(Open-Closed Principle, OCP)进行了深入探讨。在给出的代码示例中,我们可以看到一个简单的用户登录...
马士兵老师的Spring框架学习笔记会详细讲解这些概念,并结合实例帮助读者理解并掌握如何在实际项目中应用Spring框架。通过学习,你可以提升Java开发技能,更好地理解和运用Spring生态,为你的职业发展奠定坚实基础。
Spring 与 Struts 整合主要目的是利用 Spring 的 IoC 容器管理 Struts 中的 Action 对象,减少对象的重复实例化,提高性能。整合步骤包括: 1. 手动方式:Struts Action 非单例,每次请求都会实例化新的 Action,...
Spring框架是Java开发中不可或缺的一部分,它以其IoC(控制反转)和AOP(面向切面编程)的核心特性,极大地简化了企业级应用的开发。本资料“Spring学习笔记&源码”是基于网易云课堂黑马程序员的Spring四天精通课程...
Spring 笔记 Spring 是 Java 企业版(Java EE)应用程序的框架,提供了结构化的配置文件,实现了控制反转(IoC)和面向切面编程(AOP),支持表现层、业务逻辑层和持久层。Spring 的核心是 IoC 和 AOP,能够与主流...
这份笔记涵盖了Spring的核心概念和技术,包括IOC(Inverse of Control,控制反转)、DI(Dependency Injection,依赖注入)、AOP(Aspect Oriented Programming,面向切面编程)以及Spring事务管理。以下是对这些...
在传统开发中,对象通常会自行创建依赖的对象,而在Spring中,开发者只需定义对象及其依赖关系,由Spring容器负责实例化、装配以及管理这些对象。 1. **Bean定义**:在Spring中,业务对象被称为Bean。Bean定义包含...
Spring框架是Java开发中的核心组件,它以其IoC(Inversion of Control,控制反转)和AOP(Aspect Oriented Programming,面向切面编程)两大特性而著名,为开发者提供了全面的解决方案,包括依赖注入、数据访问、...
在Spring5中,开发者不再需要手动创建和管理对象,而是由Spring容器负责实例化、装配和管理,这使得代码更易于测试和维护。 2. **依赖注入(DI)**: 作为IoC的一种实现方式,依赖注入允许对象通过构造函数、...
4. **面向切面编程(AOP)**:Spring支持AOP,使得诸如权限拦截、运行时监控等功能更易于实现。 5. **集成支持**:Spring对主流的应用框架提供了良好的集成支持,例如Struts、Hibernate、JPA等。 6. **加速开发**:...
Spring框架的核心特性包括轻量级、控制反转(IoC)、面向切面编程(AOP)、容器化管理和框架集合,使其在与其他框架的整合上非常灵活。 在Spring中,bean的注入与装配是核心概念之一,有多种方式可以实现,例如XML...
3. **AOP(面向切面编程)**:Spring的AOP模块支持声明式事务管理、日志记录、性能监控等。切面是包含关注点的模块化单元,可以将横切关注点如事务逻辑应用到多个对象上。 4. **IoC容器与Bean生命周期**:Spring ...
因此,这部分笔记可能涵盖了如何使用这些工厂来实例化和管理Spring Bean。 基于以上分析,我们可以期待这篇"spring学习笔记(3.20)"中包含以下知识点: 1. **Spring框架基础**:介绍Spring的基本概念、架构和核心...
### Spring学习笔记知识点详解 #### 一、Spring框架概述 **1.1 什么是Spring** Spring框架是一个开源的轻量级应用框架,主要用于简化企业级应用程序的开发过程。它的核心特性在于提供了一种灵活的方式来组织和...
### Spring学习笔记知识点详解 #### 一、Spring框架概述 **Spring** 是一个开源的、分层的企业级应用开发框架,旨在简化Java EE应用程序的开发。它的主要目标是提高开发效率,减少耦合度,并提供一种更为简洁的...
- AOP编程支持:Spring提供AOP机制,可以方便地实现横切关注点,如事务管理、日志记录等,提高代码的复用性。 - 声明式事务管理:Spring支持声明式事务,通过注解或XML配置即可实现事务的统一管理,无需手动编写事务...
- **面向切面编程(AOP)**:Spring提供了强大的面向切面编程支持,允许开发者将横切关注点(如日志记录、事务管理等)从业务逻辑中分离出来。 - **事务处理**:Spring提供了一套完整的事务管理机制,可以方便地集成到...
2. **AOP(面向切面编程)**:AOP是Spring框架中的一个重要特性,用于处理系统中分散的、与业务逻辑无关的横切关注点,如日志记录、权限检查、事务管理等。AOP通过定义切面、通知(advice)、切入点(pointcut)等...