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的系统结构图
随机推荐
- Eclipse安装和使用TFS
第一步下载Tfs插件 去微软官网下载https://www.microsoft.com/en-us/download/details.aspx?id=4240 点击 选择下载 随便放置到一个本地或者服 ...
- c# 图片资料
- STL源码分析之迭代器
前言 迭代器是将算法和容器两个独立的泛型进行调和的一个接口. 使我们不需要关系中间的转化是怎么样的就都能直接使用迭代器进行数据访问. 而迭代器最重要的就是对operator *和operator-&g ...
- 【郑轻邀请赛 I】这里是天堂!
[题目链接]:https://acm.zzuli.edu.cn/zzuliacm/problem.php?id=2135 [题意] [题解] 答案应该为C(n,a)∗C(m,b)/C(n+m,a+b) ...
- poj3233 题解 矩阵乘法 矩阵快速幂
题意:求S = A + A2 + A3 + … + Ak.(mod m) 这道题很明显可以用矩阵乘法,但是这道题的矩阵是分块矩阵, 分块矩阵概念如下:当一个矩阵A中的单位元素aij不是一个数值而是一个 ...
- hdu_1018_Big Number_201308191556
Big NumberTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
- B - Oulipo
The French author Georges Perec (1936�C1982) once wrote a book, La disparition, without the letter ' ...
- [bzoj3694]最短路_树链剖分_线段树
最短路 bzoj-3694 题目大意:给你一个n个点m条边的无向图,源点为1,并且以点1为根给出最短路树.求对于2到n的每个点i,求最短路,要求不经过给出的最短路树上的1到i的路径上的最后一条边. 注 ...
- CODEVS——T 1049 棋盘染色
http://codevs.cn/problem/1049/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Descr ...
- springMVC入门笔记
目录 一.回顾Servlet 二.SpringMVC简介 三.搭建SpringMVC第一个案例 四.简单流程及配置 五.使用注解开发Controller 六.参数绑定 基本数据类型的获取: 如果表单域 ...