Struts2拦截器 关于解决登录的问题

拦截器的工作原理如图 拦截器是由每一个action请求(request)都包装在一系列的拦截器的内部,通过redirectAction再一次发送请求。

拦截器可以在Action执行直线做相似的操作也可以在Action执行直后做回收操作。

我们可以让每一个Action既可以将操作转交给下面的拦截器,Action也可以直接退出操作返回客户既定的画面。

接下来我们该如何定义一个拦截器:

自定义一个拦截器如下:

1、实现Interceptor接口或者继承AbstractInterceptor抽象类。

2、创建一个Struts.xml文件进行定义拦截器。

3、在需要使用的Action中引用上述定义的拦截器,为了方便也可将拦截器定义为默认的拦截器(<default-interceptor-ref name="myStack"/>),

这样在不加特殊声明的情况下所有的Action都被这个拦截器拦截<param name="excludeMethods">loginView,login</param>。

①Interceptor接口声明三个方法:

public class LoginInterceptor implements Interceptor {

 private Map<String,Object> session = null;
 public void destroy() { }
 public void init() { }
 public String intercept(ActionInvocation actionInvocation) throws Exception {
 8     Object myAction = actionInvocation.getAction();
  if(myAction instanceof UserAction){
   System.out.println("你访问的Action是UserAction,不要校验Session,否则死循环");
   //放行
   return actionInvocation.invoke();
  }else{
   System.out.println("你访问的Action是:"+myAction);
  }

  session = ActionContext.getContext().getSession();
  Object user = session.get("user");
  if (user!=null){
   return actionInvocation.invoke();
  }else{
   return "login";
  }

}

注:该方法可以不加:<param name="excludeMethods">loginView,login</param>

②让它继承 MethodFilterInterceptor:

public class LoginInterceptor extends MethodFilterInterceptor {
 private Map<String,Object> session = null;
 protected String doIntercept(ActionInvocation actionInvocation) throws Exception {
  /*
  Object myAction = actionInvocation.getAction();
  if(myAction instanceof UserAction){
   System.out.println("你访问的Action是UserAction,不要校验Session,否则死循环");
   //放行
   return actionInvocation.invoke();
  }else{
   System.out.println("你访问的Action是:"+myAction);
  }
  */
  session = ActionContext.getContext().getSession();
  Object user = session.get("user");
  if (user!=null){
   return actionInvocation.invoke();
  }else{
   return "login";
  }
 }
}

③UserAction继承ActionSupport 实现 ModelDriven<User>和SessionAware:

public class UserAction extends ActionSupport implements ModelDriven<User>,SessionAware{

 private Map<String,Object> session = null;
 private User user = null;
   //驱动模型
 public User getModel() {
  this.user = new User();
  return this.user;
 }

 public void setSession(Map<String, Object> map) {
  this.session = map;
 }

 public String loginView(){
  return "loginViewSuccess";
 }

 public String login(){
  if ("admin".equals(user.getUserName())&&"123456".equals(user.getUserPassword())){
   session.put("user",user);
   return this.SUCCESS;
  }else{
   return this.ERROR;
  }

 }
}

Struts.xml文件中:

<struts>
 <package name="myPackage" extends="struts-default">

  <interceptors>

   <interceptor name="loginInterceptor" class="com.nf.action.LoginInterceptor"></interceptor>
   <interceptor-stack name="myStack">
    <interceptor-ref name="loginInterceptor">
     <!--excludeMethods需要生效的话,自定义的拦截器,不能使用实现Interceptor接口,而是extends MethodFilterInterceptor-->
     <param name="excludeMethods">loginView,login</param><!--不用此行时 我们可以配合①使用拦截器-->
    </interceptor-ref>
    <interceptor-ref name="defaultStack"></interceptor-ref>
   </interceptor-stack>
  </interceptors>
  <!--配置一个默认拦截器,也就是所有的Action都必须使用-->
  <default-interceptor-ref name="myStack"/>
  <global-results>
   <result name="login" type="redirectAction">userAction_loginView</result>
  </global-results>
  <!--不写method,默认就是execute-->
  <action name="indexAction" class="com.nf.action.IndexAction" method="execute">
   <result name="success">/WEB-INF/jsp/index.jsp</result>
   <!--
   <interceptor-ref name="myStack"></interceptor-ref>
   -->
   <!--注释这里也可以放该代码 只不过每一个action都要放比较麻烦
   <interceptor-ref name="loginInterceptor"></interceptor-ref>
   <interceptor-ref name="defaultStack"></interceptor-ref>
   -->
  </action>

  <action name="otherFunctionAction" class="com.nf.action.OtherFunctionAction">
   <!--不写name,默认就是success-->
   <result>/WEB-INF/jsp/otherFunction.jsp</result>
  </action>

  <action name="userAction_*" class="com.nf.action.UserAction" method="{1}">
   <result name="loginViewSuccess">/WEB-INF/jsp/loginView.jsp</result>
   <result name="error">/WEB-INF/jsp/error.jsp</result>
   <result name="success" type="redirectAction">indexAction</result>
   <allowed-methods>login,loginView</allowed-methods>
  </action>
 </package>
</struts>

其中,<param name="excludeMethods">loginView,login</param> 配置的过滤方法,意思是拦截器对其中的方法不起作用。在我这里,loginView是跳转到登录页面的方法。

login 是验证用户名和密码的方法,在其中会将通过验证的用户名放入session中。

总结:

1.在struts2 中,所有的拦截器都会继承 Interceptor 这个接口。

2.如果我们没有添加拦截器,struts2 会为我们添加默认拦截器。当然我们要是指定了拦截器,我们自己的拦截器就会取代默认的拦截器,

那么我们就不能享受默认拦截器提供的一些功能。所以,一般我会把默认拦截器也加上。

例如,在以上配置项中,action 里面再加上<interceptor-ref name="defaultStack"></interceptor-ref>

以上这篇Struts2拦截器 关于解决登录的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 防止未登录用户操作—基于struts2拦截器的简单实现

    一般,我们的web应用都是只有在用户登录之后才允许操作的,也就是说我们不允许非登录认证的用户直接访问某些页面或功能菜单项.我还记得很久以前我的做法:在某个jsp页面中查看session中是否有值(当然,在用户登录逻辑中会将用户名或者用户对象存入session中),如果session中用户信息为空,那么redirect 到登录页面.然后在除了登录页面外的其它所有需要验证用户已登录的页面引入这个jsp . 比如,我们将检查用户是否登录的代码放入一个jsp页面中,如 checkUser.jsp <%@

  • Struts2开发环境搭建 附简单登录功能实例

    首先是搭建Struts2环境. 第一步 下载Struts2 去Struts官网 http://struts.apache.org/ 下载Struts2组件. 截至目前,struts2最新版本为2.3.1.3,下载struts-2.3.16.3-all.zip,解压,放着. 第二步 新建Web Project并导入jar包 在MyEclispe中新建Web Project,然后找到解压的Struts2包,在里面apps文件夹下找到struts2-blank.war,解压这个WAR文件,将里面WEB

  • struts2+jquery组合验证注册用户是否存在

    注册界面 register.jsp 复制代码 代码如下: <%@ page language="java" contentType="text/html; charset=UTF-8"%> <html> <head> <title>注册界面</title> <script type="text/javascript" src="js/jquery-1.6.js"

  • Java struts2 validate用户登录校验功能实现

    首先贴一下搭配的环境: 配置: Eclipse4.3.2 jdk1.7_45 Mysql 5.0+ 然后切入正题: 1.login.jsp 主要是使用OGNL 标签 也可使用html form表单,调用LoginAction.action,以post 方式传输. 在LoginaAction 经过判断,然后会有提示信息,需要用到 <s:fielderror/>来显示. <%@ taglib uri="/struts-tags" prefix="s"%

  • struts2与cookie 实现自动登录和验证码验证实现代码

    主要介绍struts2与cookie结合实现自动登录 struts2与cookie结合时要注意采用.action 动作的方式实现cookie的读取 struts2的jar包  链接数据库文件 db.properties dbDriver = oracle.jdbc.driver.OracleDriver url = jdbc:oracle:thin:@localhost:1521:orcl userName=test password=password dao层类代码,通过登录名获取用户信息 p

  • 详解Struts2中对未登录jsp页面实现拦截功能

    Struts2中拦截器大家都很经常使用,但是拦截器只能拦截action不能拦截jsp页面.这个时候就有点尴尬了,按道理来说没登录的用户只能看login界面不能够通过输入URL进行界面跳转,这显然是不合理的.这里介绍Struts2中Filter实现jsp页面拦截的功能.(有兴趣的人可以去研究Filter过滤器的其它用法,因为利用过滤器也可以实现action拦截的功能) 下面直接上代码,边看边分析实现步骤和原理. 1.web.xml中的配置信息: <filter> <filter-name&

  • JQuery+Ajax+Struts2+Hibernate框架整合实现完整的登录注册

    最近在仿造一个书城的网站: http://www.yousuu.com ,UI直接拿来用,前端后端自己写,目前大部分功能已经实现, 就把具体的 登录注册功能 拿来分享一下.PS:又写登录注册会不会被人喷啊=.= 一.开发环境的部署 程序结构: BootStrap+Ajax+Struts2+Hibernate+MySql 仅供参考:能实现相关功能即可 操作系统:ubuntu 14.10 前端框架:BootStrap   注:此框架只是为了实现用户界面,和具体功能无关 数据库:mysql-5.5 数

  • Struts2拦截器登录验证实例

    Struts2拦截器 Struts2拦截器的概念和Spring Mvc拦截器一样. 1.Struts2拦截器是在访问某个Action或Action的某个方法,字段之前或之后实施拦截,并且Struts2拦截器是可插拔的,拦截器是AOP的一种实现. 2.拦截器栈(Interceptor Stack).Struts2拦截器栈就是将拦截器按一定的顺序联结成一条链.在访问被拦截的方法或字段时,Struts2拦截器链中的拦截器就会按其之前定义的顺序被调用. 使用拦截器的第一步: 自定义我的权限拦截器Chec

  • 使用MyEclipse 开发struts2框架实现登录功能(结构教程)

    1.首先建立Web Project,名称为:struts2 ,然后选择Java EE6.0,点击Finish. 2.右击"struts"选择MyEclipse->Add Struts Capabilities,然后弹出如下弹窗,再选择Struts 2.1.选择完成即可点击Finish. 3.建完后项目目录如下图所示: 4.建立一个Login类,继承ActionSupport类(点击Superclass的Browse,选择搜索ActionSupport) 5.定义username,

  • 基于struts2和hibernate实现登录和注册功能

    本文实例为大家分享了struts2和hibernate实现登录和注册功能,供大家参考,具体内容如下 1.该项目使用MySQL数据库,数据库名为test,表名info,如图所示: 2.配置web.xml(Struts2使用) <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/jav

随机推荐