`
peizhiinfo
  • 浏览: 1423927 次
文章分类
社区版块
存档分类
最新评论

SSH集成框架下真正实现Spring AOP拦截功能

 
阅读更多

问题的提出:

在Struts1框架下,有三种类型的Action控制器,分别是MappingDispatchAction、DispatchAction和Action,他们是依次继承,最终执行的execute方法。但MappingDispatchAction、DispatchAction的子类中没有execute方法,只有参数指定的具体方法,而这些方法是被MappingDispatchAction、DispatchAction本类的execute方法调用执行,特别注意的是它是通过反射机制来做的(大家可以看看DispatchAction类的源代码),所以这些被反射调用的方法是不能被Spring AOP拦截的,因此也就无法利用切面编程实现权限控制了。

解决方法:

巴巴运动网通过覆盖DelegatingRequestProcessor控制器的processActionPerform方法,是一种理想的解决方案,但严格来说并不是AOP切面编程方法。因此笔者仅从学习AOP切面编程的角度来提出本文章,对于实用性笔者极力推荐巴巴运动网的方案。

本方法解决思想:

1.覆盖execute方法,再模仿DispatchAction反射调用具体的方法;

2.实现Spring AOP拦截点,开始拦截配置描述的范围内的程序;

3.在切入点程序中再次实现反射机制,获取执行方法上的权限配置信息;

4.根据权限信息决定放行还是返回。

最终既可以拦截到execute方法,也可以得到具体方法中的权限注解配置信息。以本BBS系统为例:

第一步:凡继承于DispatchAction的类都覆盖execute方法:

@Override
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) throws Exception {
return super.execute(mapping, form, request, response);
}


//假如这个action中有一个具体的方法:
@Privilege(userType=PrivilegeType.Admin,message="需管理员权限!")
public ActionForward addUI(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) throws Exception {
CategoryForm categoryForm = (CategoryForm)form;
categoryForm.setTitle("新增分类");
return mapping.findForward("addUI");
}
第二步:做自己的权限配置:

看上面addUI方法上的注解应该可以理解这些配置

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Privilege {
String message() default "您没有权限执行该操作,请登录后重试!";
PrivilegeType userType();
}
配置中有个字字段是枚举,源码如下:

public enum PrivilegeType {
LoginUser{
public String getName(){
return "所有登录用户";
}
public int getValue(){
return 1;
}
},

LoginUserSelf{
public String getName(){
return "登录用户自己";
}
public int getValue(){
return 2;
}
},

Moderator{
public String getName(){
return "版主";
}
public int getValue(){
return 3;
}
},

Admin{
public String getName(){
return "管理员";
}
public int getValue(){
return 4;
}
};

public abstract String getName();
public abstract int getValue();
}

第三步:实现AOP切入编程:

@Aspect
@Component()
public class PrivilegeAction {

//拦截com.zjh包下(含子包)所有类能返回ActionForward类型的方法
@Around("execution(org.apache.struts.action.ActionForward com.zjh..*.*(..))")
public Object validatePrivilege(ProceedingJoinPoint pjp) throws Throwable{

// 从拦截的方法中参数中得到四个对象
ActionMapping mapping = (ActionMapping) pjp.getArgs()[0];
ActionForm form = (ActionForm) pjp.getArgs()[1];
HttpServletRequest request = (HttpServletRequest) pjp.getArgs()[2];
HttpServletResponse response = (HttpServletResponse) pjp.getArgs()[3];

//从拦截点处获取它所处的类名,并经过反射取得权限配置信息
Class dispatchAction = Class.forName(pjp.getSignature().getDeclaringTypeName()); Object obj = dispatchAction.newInstance(); String mappingParament = mapping.getParameter()==null ? "execute" : request.getParameter(mapping.getParameter()); Method method = obj.getClass().getDeclaredMethod(mappingParament,
ActionMapping.class,
ActionForm.class,
HttpServletRequest.class,
HttpServletResponse.class); Privilege privilege = method.getAnnotation(Privilege.class);

//如果方法上没有配置权限信息,直接放行
if(privilege==null)
return (ActionForward)pjp.proceed();

//否则必须是登录用户,进行第一关粗粒度拦截
User user = WebUtil.getUserInSession(request);
if(user==null){
request.setAttribute("message", privilege.message());
return mapping.findForward("message");
} //再根据用户类型进行细粒度拦截
switch(privilege.userType().getValue()){
//当权限为PrivilegeType.LoginUserSelf(登录用户自己,例如更新文章必须是自
//己的文章才有权限更新)时,须从数据库里取得用户对象再和session中用
//户匹配,这个没有实现。
case 2:
if(!user.getUsername().equals("数据库里取得某文章的用户名")){
request.setAttribute("message", privilege.message());
return mapping.findForward("message");

分享到:
评论

相关推荐

    ssh2登陆+spring aop做拦截

    ssh2登陆+spring aop做拦截

    SSH框架实现BBS完整版

    该文档是SSH框架为基础实现的BBS论坛。其中有整合好的全面的SSH jar包,BBS前台,后台源码,这个小系统的报告,数据库关系分析等。 以下内容摘自报告目录部分(希望大家极力推荐哦): 第三章 SSH框架搭建 第四章 ...

    SSH权限拦截系统

    采用SSH进行开发,使用Spring的AOP对目标进行拦截,有效的控制权限。

    SSH框架实现BBS完整版.2018_03_16

    该文档是SSH框架为基础实现的BBS论坛。其中有整合好的全面的SSH jar包,BBS前台,后台源码,这个小系统的报告,数据库关系分析等。 以下内容摘自报告目录部分(希望大家极力推荐哦): 第三章 SSH框架搭建 第四章 ...

    ssh+aop+log4j+日志拦截器+注解

    ssh+aop+log4j+日志拦截器+注解

    ssh.war框架简集

    struts2+hibernate3+spring2 框架整合 aop拦截 最小ssh的jar集合

    jinxiaocun.rar_ssh进销存_权限管理系统_进销存ssh框架

    用ssh三大框架做的进销存系统,其中权限管理是亮点,基于RBAC的模型实现的权限管理,用户角色授权,用springAOP拦截方法,希望对大家学习有帮助

    SSH框架示例(可以直接用)

    ****比较适合新手理解SSH框架***** 闲下来搭了个SSH框架,写些小系统的话可以直接拿来用哦。 连接池是proxool,log4... 搭这个框架的初衷主要是想自己配置一下spring整合proxool以及aop思想对service层的事物控制等。

    Spring3+Hibernate4+Struts2 jar包 SSH框架

    spring 3.2.0+hibernate 4.1.6+struts2整合需要的jar包 的目录 antlr-2.7.7.jar aopalliance-1.0.jar asm-3.3.jar asm-commons-3.3.jar aspectjweaver-1.5.3.jar bonecp-0.7.1.RELEASE.jar cglib-2.1.3.jar ...

    SSH框架与AJAX技术的Java_Web应用开发(4页,pdf书籍)不是代码

    JSP+Servlet+Struts+Hibernate+Spring+Ajax》重点讲解了Struts 2、Speing和HIbernate框架的基础知识和高级技术,如Sruts 2中的拦截器、类型转换、国际化和标签等,HIbe rna{e的会话、0/R映射和事务管理等,Spring中...

    SSH知识大全

    TP02-Web层框架struts.ppt TP03-Struts2常用标签....Hibernate性能优化.ppt TP11-Hibernate高级特性.ppt TP12-Spring入门.ppt TP13-Spring AOP实现.ppt TP14-Spring与持久层的整合.ppt TP15-Spring与struts2的整合.ppt

    spring-boot示例项目

    本项目示例基于spring boot 最新版本(2.1.9)实现,Spring Boot、Spring Cloud 学习示例,将持续更新…… 在基于Spring Boot、Spring Cloud 分布微服务开发过程中,根据实际项目环境,需要选择、集成符合项目...

    贫血模式下的SSH处理日志管理以及对权限管理的思考

    在众多情况下,日志的管理是通过拦截器来完成的,不过通过STRUTS2的拦截器编码比较繁琐,在此通过spring的aop来处理,在贫血模式下将代码量降到最低,同时配置文件均可共用,从此,不用为日志管理浪费任何时间。

    Spring、SpringMVC和Mybatis框架整合包

    手把手教你整合最优雅SSM框架:SpringMVC + Spring + MyBatis 博客地址:http://blog.csdn.net/qq598535550/article/details/51703190 我们看招聘信息的时候,经常会看到这一点,需要具备SSH框架的技能;而且在大...

    JavaEE开发的颠覆者SpringBoot实战[完整版].part3

    在当今Java EE 开发中,Spring 框架是当之无愧的王者。而Spring Boot 是Spring 主推的基于“习惯优于配置”的原则,让你能够快速搭建应用的框架,从而使得Java EE 开发变得异常简单。 《JavaEE开发的颠覆者: Spring ...

    JavaEE开发的颠覆者SpringBoot实战[完整版].part2

    在当今Java EE 开发中,Spring 框架是当之无愧的王者。而Spring Boot 是Spring 主推的基于“习惯优于配置”的原则,让你能够快速搭建应用的框架,从而使得Java EE 开发变得异常简单。 《JavaEE开发的颠覆者: Spring ...

    JavaEE开发的颠覆者SpringBoot实战[完整版].part1

    在当今Java EE 开发中,Spring 框架是当之无愧的王者。而Spring Boot 是Spring 主推的基于“习惯优于配置”的原则,让你能够快速搭建应用的框架,从而使得Java EE 开发变得异常简单。 《JavaEE开发的颠覆者: Spring ...

    基于SSH模拟当当网项目(电子商务平台)

    5.将事务管理交个Spring,采用AOP方式,删除原有Struts事务拦截器 -------------改造步骤----------------- 例如用户注册功能 1) 引入Hibernate开发包 2) 引入Spring开发包和配置文件 applicationContext-base....

    低清版 大型门户网站是这样炼成的.pdf

    8.5 新闻采集功能实现 562 8.6 小结 573 第9章 会员注册及会员管理系统 575 9.1 会员管理系统需求分析 575 9.2 会员管理系统功能设计 576 9.3 会员级别后台管理 578 9.3.1 展示层jsp 2+struts 2标签库实现 579...

    基于JavaWEB+SSM+mysql框架构建的在线商城系统源码+数据库+项目说明(课程设计).zip

    [SSH版(实现了SSM版95%功能)][3] [Servlet版(实现了SSM版85%功能)][2] ---------------------------- 本项目的亮点: * 功能齐全,页面丰富,实现了小商城的大部分功能 * 前端仿天猫2017页面,基于原生 ...

Global site tag (gtag.js) - Google Analytics