struts2拦截器

一.struts2框架整体流程

struts2拦截器_第1张图片
struts2-3.jpg
struts2拦截器_第2张图片
Paste_Image.png
struts2拦截器_第3张图片
Paste_Image.png

二.第一个demo

1.创建被拦截的action

package com.lxf.timerintercepter;
/**
 * 做一个耗时的actioin,用拦截器统计该action执行的时间
 */

import com.opensymphony.xwork2.ActionSupport;

public class TimerAction extends ActionSupport{

    @Override
    public String execute() throws Exception {
            for(int i=0;i<10000;i++)
            {
                System.out.println("I LOVE IMOOC");
            }
            return SUCCESS;
    }
    
}

2.创建拦截器

package com.lxf.timerintercepter;
/**
 * 拦截器,用来计算timerAction的执行时间
 */

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

public class TimerIntercepter extends AbstractInterceptor {

    /**
     * 自动调用此方法,进行拦截操作
     */
    @Override
    public String intercept(ActionInvocation invocation) throws Exception {
           //1.执行Action之前
           long start = System.currentTimeMillis(); //获得当前的毫秒值
           //2.执行下一个拦截器,如果已经是最后一个拦截器,则执行目标action
           String res = invocation.invoke();
           //3.执行Action之后
           long end = System.currentTimeMillis(); 
           System.out.println("执行Action话费的时间:" + (end - start) + "ms");
           //将最终调用Action之后的结果视图返回   
           return res;
    }

}

3.在Timer.xml中注册和在对应action中引用拦截器




    
        
        
            
        
        
            /result.jsp
            
            
        
    
   

4.在struts.xml中包含timer.xml




    
    
    
    
     
    
    
    
    
    
    
    
    
   

5.将项目部署到tomcat上,访问地址:

http://localhost:8081/struts2-test1/myTimer/timerAction.action

查看控制台拦截器产生作用:

...
I LOVE IMOOC
I LOVE IMOOC
I LOVE IMOOC
执行Action话费的时间:29ms

三.struts2内置拦截器

struts2拦截器_第4张图片
Paste_Image.png
struts2拦截器_第5张图片
Paste_Image.png
  • 内置拦截器我们可以查看struts2核心jar包struts2-core-2.3.1.jar中的struts-default.xml

  • 在struts-default.xml中配置了默认拦截器栈


    struts2拦截器_第6张图片
    Paste_Image.png
  • 所以推荐在自己显示为某个action引用拦截器之前,将默认拦截器栈先手动引用




    
        
        
            
        
        
            /result.jsp
            
            
            
            
        
    
   

四.使用拦截器实现对用户登录验证

1.在WEB_INF目录中简历/page/manager.jsp,作为用户后台页面.

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>




Insert title here


后台管理页面,只有已登录的页面才能够访问!


2.写loginNew.jsp登录页

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>




Insert title here


用户登陆

${loginError}
用户名: 密码:

3.写登录LoginNewAction.java

package com.lxf.action;
/**
 * 用户登录页面,用来判断用户是否登录
 */

import java.util.Map;

import org.apache.struts2.interceptor.SessionAware;

import com.opensymphony.xwork2.ActionSupport;

public class LoginNewAction extends ActionSupport implements SessionAware{
    private String username;
    private String password;
    private Map session;
    /**
     * 实现SessionAware中的接口
     */
    @Override
    public void setSession(Map session) {
        this.session = session;
        // TODO Auto-generated method stub
    }
    
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;   
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    
    /**
     * 处理登录请求
     */
    public String loginNew()    
    {
        if("admin".equals(username) && "123".equals(password))
        {
            session.put("loginInfo", username);
            return SUCCESS;
        }else
        {
            session.put("loginError", "用户名或密码不正确!");
            return ERROR;
        }
    }
}

4.写AuthIntercepter.java拦截器

package com.lxf.timerintercepter;
/**
 * 拦截器,用来验证用户登录
 */

import java.util.Map;

import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

public class AuthIntercepter extends AbstractInterceptor {

    /**
     * 自动调用此方法,进行拦截操作
     */
    @Override
    public String intercept(ActionInvocation invocation) throws Exception {
           ActionContext context = ActionContext.getContext();
           Map session = context.getSession();
           //用户已登录
           if(session.get("loginInfo") !=null)
           {
               String result = invocation.invoke();
               return result;
           }else
            //用户未登录
           {
               return "login";
           }
    }
}

4.配置自定义manager.xml配置文件:



 

    
        
        
            
            
            
                
                
            
        
        
        
        
            /WEB-INF/page/manager.jsp
            /loginNew.jsp
            
            
        
        
        
        
            /WEB-INF/page/manager.jsp
            /loginNew.jsp
        
    
   

5.在struts.xml中引用manager.xml




    
    
    
    
     
    
     
    
    
    
    
    
    
    
    
    
    
   

6.在没有登录的情况下,访问:

http://localhost:8081/struts2-test1/manager/auth.action

过滤器会判断是否登录,如果登录了则跳转套manager.jsp页面,否则跳转套登录页面

你可能感兴趣的:(struts2拦截器)