Struts2 在拦截器中向Action传参
struts.xml配置文件:
<package name="system-default" extends="struts-default" abstract="true">
<!-- struts2拦截器,拦截方法 -->
<interceptors> <!-- 定义拦截器栈,所谓拦截器栈,是指由一个或多个拦截器组成
struts2 提供的拦截器栈,包含了struts2的很多核心拦截器
自己定义的放在最后面,struts2定义的放在前面
--> <interceptor-stack name="default-stack">
<interceptor-ref name="defaultStack"></interceptor-ref>
<!-- 登录拦截器 -->
<interceptor-ref name="webLoginInter"> <param name="excludeMethods">
toLogin,
getSessionValiCode,
login,
toRegister,
register,
regAgreement,
logout
</param>
</interceptor-ref> <!-- includeMethods表示包含指定的方法,即对标记为includeMethods的方法进行拦截,对应Action映射method --> </interceptor-stack>
</interceptors>
<default-interceptor-ref name="default-stack"></default-interceptor-ref> <global-results>
<!--将cookie里的信息传递到login方法中进行自动登录-->
<result name="login" type="redirectAction">>
<param name="namespace">/info</param>
<param name="actionName">login</param>
<!--userInfo.loginName:userInfo是要跳转至的Action中的某一属性名,loginName是该userInfo对象里的某一字段名,花括号里的字段名,对应拦截器里自定义的"key"-->
<param name="userInfo.loginName">${loginName}</param>
<param name="userInfo.loginWord">${loginWord}</param>
</result>
</global-results>
</package>
java(拦截器)代码:
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.util.Map; import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.apache.struts2.ServletActionContext; import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.MethodFilterInterceptor; //可以继承 MethodFilterInterceptor ,也可以继承 AbstractInterceptor,此处两者都可以用
public class WebLoginInterceptor extends MethodFilterInterceptor{ private String excludeMethods;//在struts.xml中定义的参数,不拦截这些方法 public String getExcludeMethods() {
return excludeMethods;
} public void setExcludeMethods(String excludeMethods) {
this.excludeMethods = excludeMethods;
} //获取struts.xml中配置的不需要拦截的 methodName组,与当前请求的methodName进行匹配,如果包含则返回true
private boolean isExcludeMethods(String methodName)
{
boolean flag=false;
String [] excludeMethodsArray = excludeMethods.split(",");
for (int i = 0; i < excludeMethodsArray.length; i++) {
String excludeMethod=excludeMethodsArray[i].replace("\n", "").replace("\t", "").replace(" ", "");
if (methodName.equals(excludeMethod)) {
flag=true;
break;
}
} return flag;
} /*
*根据索引获取cookie中的信息,
*注意:在javascript中设置cookies时要先做encodeURIComponent(),不然一些特殊字符传到这里来会丢失
*/
private String getCookieByIndex(HttpServletRequest request,int index)
{
String returnStr="";
String nm="";
String psd="";
String invalidDate="";
String isLogin="";
try {
Cookie[] cookies=request.getCookies();
for(Cookie cookie : cookies)
{
//username 是cookie参数名(key)
if("username".equals(cookie.getName()))
{
//获取参数值
String userStr = new String(cookie.getValue());
//客户端做过encode,这里要decode
userStr=URLDecoder.decode(userStr,"UTF-8"); //此处根据自己业务来,当前项目是用以下特殊符号将用户名密码等信息分割开来放在一个参数中,所以才这样写
if (userStr!=""){
int index1 = userStr.indexOf("%%");
int index2 = userStr.indexOf("&&");
int index3 = userStr.indexOf("##");
if(index1>-1)
{
nm=userStr.substring(0,index1);
if(index2>-1)
{
psd=userStr.substring(index1+2,index2);
}
}
if(index3>-1)
{
if(index2>-1)
{
invalidDate=userStr.substring(index2+2,index3);
}
isLogin= userStr.substring(index3+2);
} }
break;
}
}
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} //用户名
if(index==1)
{
returnStr=nm;
}
//密码
if(index==2)
{
returnStr=psd;
}
//失效日期
if(index==3)
{
returnStr=invalidDate;
}
//是否登录
if(index==4)
{
returnStr=isLogin;
} return returnStr;
} //用户未登录的情况下,拦截非ajax请求,根据cookie里的相关信息进行自动登录
@Override
public String doIntercept(ActionInvocation actionInvocation) throws Exception { String result = null;
try {
Map<String,Object> session = ActionContext.getContext().getSession(); HttpServletRequest request = ServletActionContext.getRequest();
HttpServletResponse response = ServletActionContext.getResponse(); //获取请求Namespace
String namespace = actionInvocation.getProxy().getNamespace();
//获取请求ActionName
String actionName = actionInvocation.getProxy().getActionName();
//获取请求Method
String method = actionInvocation.getProxy().getMethod();
//获取请求方法
String name = actionInvocation.getInvocationContext().getName();
//获取请求参数
Map<String,Object> params = actionInvocation.getInvocationContext().getParameters(); //被拦截URL地址
String url=request.getScheme()+"://";
url+=request.getHeader("host");
url+=request.getRequestURI();
if(request.getQueryString()!=null){
url+="?"+request.getQueryString();
} //从session中得到userInfo
if(userInfo==null)
{
//过滤不需要拦截的方法名
if(isExcludeMethods(method)==true)
{
return actionInvocation.invoke();
}
//由于ajax请求不受控(不会根据返回的result进行跳转),因此只对http请求做处理
if(request.getHeader("X-Requested-With") == null || !request.getHeader("X-Requested-With").equalsIgnoreCase("XMLHttpRequest"))
{
//获取cookie里的值,判断是否满足自动登录的条件,满足就自动登录
String nm=getCookieByIndex(request,1);
String psd=getCookieByIndex(request,2);
String isLogin= getCookieByIndex(request,4);
//用户名密码不为空,且用户勾选过自动登录
if("1".equals(isLogin) && !"".equals(nm) && !"".equals(psd))
{
log.info("action name:" + actionInvocation.getAction());
log.info("functional action name:" + actionName);
log.info("使用cookie中保存的用户信息进行自动登录..."); ///!!!!此处是关键
//将用户名密码存入值栈中,以便于传递到其他的Action,对应struts.xml中的配置
actionInvocation.getStack().set("loginName", nm);
actionInvocation.getStack().set("loginWord", psd); //重定向到UserInfoAction的login方法中,login方法是一个登录方法,转到这个方法之后,会进行正常的登录操作
return "login";
}
} } result = actionInvocation.invoke();
} catch (Exception e) {
actionInvocation.getInvocationContext().put("errorMsg", e.getMessage());
e.printStackTrace(); } return result;
} }
javascript代码:
就两个方法
1.设置cookie
2.获取cookie
对 document.cookie 的值来进行读、写就可以了
写入时记得要encodeURIComponent()
读取时记得要decodeURIComponent()
Struts2 在拦截器中向Action传参的更多相关文章
- 如何在Struts2的拦截器中调用Spring容器
第一种: 通常用ApplicationContext来调用Spring配置文件中的一些Bean,所以首先创建Spring上下文容器. ApplicationContext ac = (Applicat ...
- struts2 在拦截器进行注入(依据Action是否实现自己定义接口)
比如:经常在Action中都须要获取当前登录的User,就须要获取Session.然后从Session获取当前登录的User,由于这些步骤都是反复操作,能够想办法在拦截器中进行实现.能够自己定义一个接 ...
- 【Java EE 学习 35 下】【struts2】【struts2文件上传】【struts2自定义拦截器】【struts2手动验证】
一.struts2文件上传 1.上传文件的时候要求必须使得表单的enctype属性设置为multipart/form-data,把它的method属性设置为post 2.上传单个文件的时候需要在Act ...
- Struts2学习第四天——拦截器及文件上传
1.概述 Struts2的很多核心功能都是由拦截器完成的. 拦截器很好的实现了AOP的编程思想,在动作的执行之前和结果的返回之后,做拦截处理. 2.struts2的默认拦截器栈 3.自定义拦截器 St ...
- 深入分析JavaWeb Item47 -- Struts2拦截器与文件上传下载
一.struts2中的拦截器(框架功能核心) 1.过滤器VS拦截器 过滤器VS拦截器功能是一回事. 过滤器是Servlet规范中的技术,能够对请求和响应进行过滤. 拦截器是Struts2框架中的技术. ...
- struts文件上传拦截器中参数的配置(maximumSize,allowedTypes ,allowedExtensions)问题
<interceptor-ref name="fileUpload"> <param name="allowedTypes">image ...
- [技巧篇]08.Struts2拦截器中获取Servlet API方法
讲课中遇到的解决Session拦截器的后腿问题,还有如何在拦截器中获取Servlet API,这里留一个备注,方便学生查找
- Struts2 在登录拦截器中对ajax请求的处理
前言: 由于ajax请求不像http请求,可以直接进行页面跳转,你返回的所有东西,ajax都只会识别为一个字符串. 之前尝试的方法是在拦截器中返回一个标识给ajax,然后再在每一个ajax请求成功之后 ...
- struts2总结六: Struts2的拦截器
一.Struts2的系统结构图
随机推荐
- react 父组件给子组件传值
父组件 import React from 'react'import '../page1/header.css'import { Table } from 'antd'import Child fr ...
- uvalive 3231
3231 - Fair ShareAsia - Seoul - 2004/2005You are given N processors and M jobs to be processed. Two ...
- inet_XX族函数
在网络编程中, 经常会将网络字节转为本地字节或者将本地字节转为网络字节, 但是如果每次我们都是都通过htonl, ntohl函数需要将10进制转为整数, 甚至还用将字符串转为整数, 再转为网络字节, ...
- 49.ardinality算法之优化内存开销以及HLL算法
主要知识点 precision_threshold参数的理解 HLL算法优化(hash) cardinality,count(distinct),5%的错误率,性能在100ms左右 ...
- PAT 1100. Mars Numbers
People on Mars count their numbers with base 13: Zero on Earth is called "tret" on Mars. T ...
- 学习记录--让我打开另一种思路的SQL
1.显示文章.提交人和最后回复时间 select a.title,a.username,b.adddate from table a, (select max(adddate) adddate fro ...
- Python 4 循环语句while
while [条件]: 条件这里满足布尔运算True则无限循环while里面代码. 固定条件的 基本的while循环, 如果if匹配那么 则执行打印登录成功,和break跳出整个循环, ...
- 【原创】TCP超时重传机制探索
TCP超时重传机制探索 作者:tll (360电商技术) 1)通信模型 TCP(Transmission Control Protocol)是一种可靠传输协议.在传输过程中当发送方(sender)向接 ...
- HDU 4405 Aeroplane chess (概率DP求期望)
题意:有一个n个点的飞行棋,问从0点掷骰子(1~6)走到n点须要步数的期望 当中有m个跳跃a,b表示走到a点能够直接跳到b点. dp[ i ]表示从i点走到n点的期望,在正常情况下i点能够到走到i+1 ...
- 自己定义控件-仿iphone之ToggleButton&VoiceSeekBar
由于项目中须要使用开关切换button,和声音滑动控件,可是原生Android5.0版本号以下的控件实在是太挫了.尽管网上已经有非常多关于这两个控件的blog.可是我实在是找不到像iPhone这样简洁 ...