- 浏览: 658353 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (609)
- java (139)
- 数据库 (107)
- 微信 (23)
- IT生活 (5)
- web前端 (74)
- SSH (11)
- 设计模式 (12)
- 重要资料 (11)
- 其他 (15)
- java技巧 (23)
- 服务器 (9)
- 2D/GUI (3)
- JAVA3D (2)
- ANT (5)
- Apache项目 (19)
- 数据类型 (10)
- 报表 (3)
- Collections (6)
- SQL/JDBC (15)
- 开发类 (6)
- EJB (6)
- Email (6)
- 文件读写 (2)
- 游戏 (0)
- Flex (2)
- Generic (2)
- HIbernate (12)
- I18N (5)
- Java EE (9)
- java ME (4)
- JDK 6 (8)
- JNDI/LDAP (5)
- JSP (7)
- JSTL (2)
- 正则表达式 (2)
- 安全 (2)
- Struts2 (12)
- Spring (4)
- Web服务 (10)
- Xml (1)
- JavaScript (30)
- AJAX (7)
- 验证 (4)
- 上传下载 (1)
- office办公软件 (1)
- Android (2)
- IOS (0)
- Dubbo (3)
- memcached/redis (1)
- 小程序 (1)
- 微信公众号 (0)
最新评论
-
wf_wangfeng:
怎么我用第一种方法不行呢 alert(document.rea ...
当jsp页面完全加载完成后执行一个js函数 -
Lori_Liu:
有帮助,至少可以解决了目前所遇到的问题!谢谢..
当jsp页面完全加载完成后执行一个js函数 -
starbhhc:
String actionMessage = new Stri ...
Java读取txt文件乱码 -
starbhhc:
Sev7en_jun 写道GOOD
客气,互相交流。。
javaeye论坛规则小测验(答案)--star -
Sev7en_jun:
GOOD
javaeye论坛规则小测验(答案)--star
用户登录之后session我们设置一定的时间失效,失效后页面的转向问题一般都是跳回主页或者是我们自定义的页面 action: 如果注册页面的请求也包含在拦截器的拦截中加以判断: 这里用户的拦截器定义在user包下 全局拦截器的定义: Struts2分别对Request、Session和Application三个对象封装成了三个Map对象,直接使用封装好的Map对象来读取和保存数据。可以通过com.opensymphony.xwork2.ActionContext类来得到这三个对象。ActionContext是Action执行的上下文,保存了很多对象如parameters、request、session、application和locale等。通过ActionContext类获取Map对象的方法为: web.xml配置package com.tkbs.web.interceptors;
import java.util.Date;
import java.util.Map;
import javax.annotation.Resource;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;
import com.tkbs.domain.user.UserAccounts;
import com.tkbs.service.user.UserService;
/**
* 用户拦截器
* author zxg
* version 1.0
*/
public class UserInterceptor implements Interceptor {
private static final long serialVersionUID = 5582842221490358379L;
public void destroy() {
}
/**
* 在服务启动的时候执行
*/
public void init() {
}
public String intercept(ActionInvocation actionInvocation) throws Exception {
System.out.println("<<<教师拦截器初始化...");
ActionContext ctx = ActionContext.getContext();
Map session = ctx.getSession();
// sessionUser 如果session中不存在用户在返回index视图
if (session.get("sessionUser")== null) {
return "index";
}
String result = actionInvocation.invoke();
return result;
}
}
package com.tkbs.web.interceptors;
import java.util.Date;
import java.util.Map;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts2.ServletActionContext;
import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;
import com.tkbs.domain.user.UserAccounts;
import com.tkbs.service.user.UserService;
/**
* 用户拦截器
* author zxg
* version 1.0
*/
public class UserInterceptor implements Interceptor {
private static final long serialVersionUID = 5582842221490358379L;
public void destroy() {
}
/**
* 在服务启动的时候执行
*/
public void init() {
}
public String intercept(ActionInvocation actionInvocation) throws Exception {
System.out.println("<<<教师拦截器初始化...");
ActionContext ctx = ActionContext.getContext();
Map session = ctx.getSession();
// sessionStudent
if (session.get("sessionUser")== null) {
//判断是不是注册用户,如果是注册用户(包含userRegisterPage)则继续执行,否则跳转到index视图
HttpServletRequest request = (HttpServletRequest)ctx.get(ServletActionContext.HTTP_REQUEST);
String uri = request.getRequestURI();
if(uri.indexOf("userRegistPage") == -1) {
return "index";
}
}
String result = actionInvocation.invoke();
return result;
}
}
User包下拦截器
<!-- user 包配置 -->
<package name="user" extends="myDefault" namespace="/user">
<interceptors>
<interceptor name="userInterceptor"
class="com.tkbs.web.interceptors.UserInterceptor">
</interceptor>
<interceptor-stack name="userStack">
<interceptor-ref name="userInterceptor"></interceptor-ref>
<interceptor-ref name="myDefaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 默认拦截器,此包下所有的ACTION将都被拦截。如果ACTION再定义了拦截器,则失效 -->
<default-interceptor-ref name="userStack"></default-interceptor-ref>
<global-results>
<!-- 首页-->
<result name="index">/index.jsp</result>
</global-results>
<!-- *_*_*
页面转向${ctp}/page/resource_queryResource_resourceList
...actions.page.resource.queryResource[method=resourceList]
...actions.page.resource.queryResourceDetial[method=resourceDetial]
-->
<action name="*_*_*" class="{2}Action" method="{3}">
<result name="update" type="redirectAction">
<param name="actionName">
userDiary_userDiary_diaryShow
</param>
<param name="namespace">/user</param>
<param name="parse">true</param>
<param name="diaryId">${diaryId}</param>
<param name="userId">${userId}</param>
</result>
<!-- page 与包相应 -->
<result name="{3}" type="dispatcher">
/modulePage/{1}/{3}.jsp
</result>
<!-- json -->
<result name="json" type="json" />
<!-- user -->
<result name="pwdUpOff" type="redirectAction">
<param name="namespace">/user</param>
<param name="actionName">
userUser_user_userIndex
</param>
<param name="parse">true</param>
</result>
</action>
</package>
全局拦截器:
<!-- default (全局)包配置 -->
<package name="myDefault" extends="json-default" namespace="/">
<interceptors>
<interceptor name="configInterceptor"
class="com.tkbs.web.interceptors.ConfigInterceptor">
</interceptor>
<!-- 默认的必须放在最下面! -->
<interceptor-stack name="myDefaultStack">
<interceptor-ref name="configInterceptor"></interceptor-ref>
<interceptor-ref name="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 默认拦截器,此包下所有的ACTION将都被拦截。如果ACTION再定义了拦截器,则失效 -->
<default-interceptor-ref name="myDefaultStack"></default-interceptor-ref>
<global-results>
<!-- 首页-->
<result name="index">/index.jsp</result>
<result name="adminLoginPage">
/moduleAdmin/index/adminLogin.jsp
</result>
</global-results>
<!-- 用户登录 login_adminLogin/userLogin-->
<action name="login_*" class="loginAction" method="{1}">
<!-- 前台用户登录 userLogin-->
<result name="loginMessage" type="json"></result>
<result name="adminLogSuccess" type="redirectAction">
<param name="actionName">
index_indexManage_adminIndex
</param>
<param name="namespace">/admin</param>
</result>
<result name="adminLoginIn">
/moduleAdmin/index/adminIndex.jsp
</result>
<result name="adminLoginPage">
/moduleAdmin/index/adminLogin.jsp
</result>
</action>
<!-- 用户退出登录-->
<action name="existLogin_*" class="existLoginAction"
method="{1}">
<result name="index">/index.jsp</result>
</action>
</package>
ActionContext context=ActionContext.getContext(); --得到Action执行的上下文
Map request=(Map)context.get("request");--得到HttpServletRequest的Map对象
Map session=context.getSession();--得到HttpSession的Map对象
Map application=context.getApplication();--得到ServletContext的Map对象
HttpServletRequest request = (HttpServletRequest)context.get(ServletActionContext.HTTP_REQUEST);
HttpServletRequest request = ctx.get(org.apache.struts2.StrutsStatics.HTTP_REQUEST);<!-- session超时定义,单位为分钟 -->
<session-config>
<session-timeout>20</session-timeout>
</session-config>
<!-- struts2 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>
<!--org.apache.struts2.dispatcher.FilterDispatcher-->
org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
<!-- 配置struts2的CleanUp的Filter -->
<filter>
<filter-name>struts-cleanup</filter-name>
<filter-class>
org.apache.struts2.dispatcher.ActionContextCleanUp
</filter-class>
</filter>
<filter-mapping>
发表评论
-
maven项目第一行报错:org.apache.maven.archiver.MavenArchiver.getManifest(org.apache.mave
2020-04-09 01:23 509maven项目第一行报错:org.apache.maven.a ... -
删除项目中的所有.svn文件夹(或CVS文件夹)
2019-06-06 19:19 519当你的项目用SVN管理时,在项目的每个文件夹中会多一个.svn ... -
eclipse下生成Java类图和时序图,生成UML图
2016-12-30 02:28 2065最近老板让我做类图和时序图,提苦恼的,完全不会,就从网上整理 ... -
eclipse使用ModelGoon插件自动生成java类的UML图
2016-12-30 02:23 12431、ModelGoon介绍 ModelGo ... -
linux下的tomcat jvm内存
2016-11-30 23:19 593常见的内存溢出有以下两种: Java.lang.OutOf ... -
FTP实现客户端与服务器文件传输(二)
2016-08-06 01:22 1020/*以sun开头的class不是java里面的标准类,而是 ... -
java实现文件转换成二进制存储与取出
2016-08-06 01:21 2743一、功能描述: 将文件转成二进制数据放入数据库中,需要的 ... -
Resource specification not allowed here for source level below 1.7
2016-08-05 11:14 1181现象:tomcat能正常启动,但打开页面时,出现上面的错误 ... -
使用commons.net FTP 和sun.net.ftp.FtpClient 多种方式上传下载(包括批量)删除功能(一)
2016-08-04 10:38 686使用commons.net FTP 上传下载删除功能 ... -
第十一节 CAS服务端RememberMe
2016-06-07 11:03 1192关于启用RememberMe功能所需做的修改描述 ... -
第七节:CAS4.0.0 以上服务端配置多个数据源
2016-06-03 14:50 11311.首先打开deployerConfigContext.x ... -
第六节:CAS服务端自定义数据库认证用户
2016-06-03 11:46 2372/** * @see --------------- ... -
第四节:将CAS https的认证方式改为http
2016-06-01 08:49 1696一、CAS Server端的修改 1、找到cas\W ... -
java 读取html过滤标签
2016-05-27 16:19 994public static void main(Strin ... -
获取cookie
2016-05-26 16:07 823获取cookie -
spring同时集成redis和mongodb时遇到多个资源文件加载的问题
2016-05-14 15:40 773两天平台中集成redis和mongodb遇到一个问题 单独 ... -
Windows上安装OpenSSL和生成证书
2016-05-10 15:52 23981,先下载OpenSSL http://www.slpr ... -
4.ubuntu14.04 安装mongodb笔记
2016-05-06 08:52 6741、使用系统自动获取安装。 1)获取更新 s ... -
3.nodejs nodejs的mysql模块
2016-04-12 22:20 579安装nodejs的mysql模块首先要选定一个数据库,我选择 ... -
第二节:cas处理中文乱码
2016-04-07 11:38 1324cas service配置参考第一节。 casServi ...
相关推荐
在这个文档中,我们关注的是Struts2的拦截器(Interceptor)的使用,特别是如何在用户Session失效后将其重定向到一个统一的页面。拦截器是Struts2框架的核心组件之一,它在Action执行前后执行特定的逻辑,提供了扩展...
通过以上详细介绍,我们了解了Struts2中的拦截器和验证框架的基本概念、如何创建自定义拦截器以及如何配置拦截器和使用验证功能。这些知识点对于初学者来说非常重要,能够帮助他们更好地理解和使用Struts2框架。
通过这种方式,当用户的Session失效后,用户仍然可以收到错误提示,并能够被引导回登录页面,从而能够重新登录继续使用应用。 此外,文章中提及的SecurityContextUtil是一个用于维护用户安全上下文的工具类。在拦截...
- Struts2拦截器:如果需要在Struts2中使用缓存,可以自定义拦截器,实现请求前检查缓存,请求后更新缓存的功能。 6. **优化与实践**: - 使用Redis的发布/订阅(Pub/Sub)功能进行消息通信,例如通知缓存更新。 -...
- Struts2的拦截器或自定义过滤器会检测到这个Cookie,读取其值并解密。 - 检查解密后的Token是否存在于服务器的Session中。如果存在,说明该用户已经通过了身份验证,可以直接跳转到主页面,实现自动登录效果;...
Struts的配置文件可以设定拦截器链,确保用户在未验证的情况下无法访问受保护的页面。 总的来说,解决用户退出问题需要多方面的考虑,包括但不限于session管理、HTTP响应头的设置、防止页面缓存以及利用MVC框架如...
- **预处理**:可以使用Struts2的内置拦截器或自定义拦截器,在Action执行前进行一些操作,如权限检查。 - **后处理**:在Action执行后,拦截器可以做一些收尾工作,如记录日志。 8. ** session管理** - **登录...
当用户首次访问需要进行表单操作的页面时,Struts2会在用户的会话中生成一个唯一的令牌值,并将其存储在`session`中。这通常通过在表单中加入以下代码片段来实现: ```xml <s:token name="user.token"></s:token> ``...
在实际应用中,Struts2的拦截器(Interceptor)机制也可以用来增强验证码的处理。例如,可以编写一个专门的拦截器,对每个请求检查是否需要验证码,以及验证用户输入的验证码是否正确。 总的来说,Struts2图片...
因此,我们可以在服务器端的拦截器(如Struts2的Interceptor)中检查这个字段,以此来区分AJAX请求和普通请求。 以下是一个简单的示例,展示了如何在Struts2拦截器中处理这个问题: ```java public String ...
1. **配置Action**:在Struts的配置文件(struts.xml或struts.properties)中,为需要防止重复提交的Action添加一个拦截器,通常是`token`和`tokenSession`拦截器。 2. **生成Token**:在Action的准备方法(Prepare...
以下是一个简单的Struts2拦截器示例,用于处理Ajax请求和Session失效的情况: ```java public String intercept(ActionInvocation invocation) throws Exception { ActionContext ac = invocation....
对于Struts框架,可以利用Struts的拦截器实现自定义的登录验证逻辑,结合上述方法实现跨服务器的登录状态一致性。 总之,处理多台Web服务器的登录问题,需要考虑系统的扩展性、性能和安全性,选择合适的技术方案并...
在struts-config.xml中,添加`token`拦截器到Action配置中,确保它在`execute`拦截器之前: ```xml ``` #### 2.3 表单处理 在JSP页面上,添加一个隐藏字段来存放令牌值: ```jsp <!-- form fields -->...
`<interceptor-ref name="token">`表示使用了令牌拦截器,`<param name="strict">true</param>`表示开启严格模式,即当令牌失效时,会抛出异常,而不是简单地返回输入页面。 此外,`TokenAwareActionSupport`类是...
- 在Action类中,可以使用`TokenSessionStore`拦截器,它会在用户请求时生成Token,并将其存入Session。 - 在JSP页面中,通过`s:token`标签生成隐藏字段,将Token放入表单中。 - 提交表单时,`TokenSessionStore`...
统一异常处理策略,如使用Spring的@ControllerAdvice或Struts2的全局异常拦截器。 以上只是部分常见的SSH整合错误,实际开发中可能还会遇到其他问题。解决这些问题需要对SSH框架有深入理解,熟悉其内部原理和配置...
其核心概念包括拦截器(Interceptor)、结果类型(Result)和Action配置。在实际开发中,可能会遇到如Action调用异常、视图解析错误等问题,解决方法通常涉及检查配置文件、依赖注入及Action类的编写。 2. **Spring...