javaweb之session过期验证
session过期判断的基本思想:用户登录成功后,将用户账号信息保存在session中,然后几乎每次执行命令都要经过过滤器,过滤器检查session中是否存在账号,若不存在,
则返回登录页面,反之正常执行。
1、web.xml中添加
<filter><!-- 配置过滤器,用来检查session中是否存在用户登录账号信息 -->
<filter-name>ChkSessionFilter</filter-name>
<filter-class>com.um.core.filter.LoginFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>ChkSessionFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- 配置session过期时间 -->
<session-config>
<session-timeout>20</session-timeout>
</session-config>
<welcome-file-list>
2、fiter
package com.um.core.filter; import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession; import com.um.core.controller.BaseController; /**
* 登录验证过滤器
*/
public class LoginFilter extends BaseController implements Filter { /**
* 初始化
*/
public void init(FilterConfig fc) throws ServletException {
// FileUtil.createDir("d:/FH/topic/");
} public void destroy() { } public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) req;
HttpServletResponse response = (HttpServletResponse) res;
String[] notFilter = new String[] { "userLogin","js","xml","css","demo","img","images","fonts","common","gateway","payCallback","toOrderPage","show_order"};//过滤字段、路径。。。。。。
String urlPath = request.getServletPath();
Boolean flg = false;
for (String url : notFilter) {
if ((urlPath.contains(url))) {
flg = true;
}
}
if(flg){
chain.doFilter(req, res);
}else{
HttpSession session = request.getSession();
String UID = (String) session.getAttribute("UID"); //登录成功将登录ID放入session中,这里将session取出对比
if (null == UID||"".equals(UID)) {
logger.warn("用户登录超时或未登录,请重新登录!");
java.io.PrintWriter out = response.getWriter();
out.println("<html>");
out.println("<script>");
out.println("window.open ('"+request.getContextPath()+"/login.jsp','_top')");
out.println("</script>");
out.println("</html>");
return; }else {
chain.doFilter(req, res);
}
} }
}
javaweb之session过期验证的更多相关文章
- ASP.NET MVC Session 过期验证跳转至登入页面
		
一.在要检查登入的控制器上继承 CheckLoginController 类 2. CheckLoginController 类的写法 using System; using System.Colle ...
 - Javaweb设置session过期时间
		
在Java Web开发中,Session为我们提供了很多方便,Session是由浏览器和服务器之间维护的.Session超时理解为:浏览器和服务器之间创建了一个Session,由于客户端长时间(休眠时 ...
 - [转]菜鸟程序员之Asp.net MVC Session过期异常的处理
		
本文转自:http://www.cnblogs.com/JustRun1983/p/3377652.html 小赵是刚毕业的计算机专业方面的大学生,4年的大学时间里面,他读过了很多编程方面的数据,也动 ...
 - 菜鸟程序员之Asp.net MVC Session过期异常的处理
		
小赵是刚毕业的计算机专业方面的大学生,4年的大学时间里面,他读过了很多编程方面的数据,也动手也了很多代码.现在毕业了,他如愿的加入了T公司,开始了自己的程序员生涯.他信心满满,相信自己4年的学习到的东 ...
 - 关于web会话中的session过期时间的设置
		
关于web会话中的session过期时间的设置 1.操作系统: 步骤:开始——〉管理工具——〉Internet信息服务(IIS)管理器——〉网站——〉默认网站——〉右键“属性”——〉主目录——〉配置— ...
 - js--Ajax的小知识(二):处理ajax的session过期的请求
		
问题的产生: 现如今Ajax在Web项目中应用广泛,几乎可以说无处不在. 有时会碰到这样个问题:当Ajax请求遇到Session超时,应该怎么办? 显而易见,传统的页面跳转在此已经不适用,因为Ajax ...
 - Cookie、Session登陆验证相关介绍和用法
		
一.Cookie和Session 首先.HTTP协议是无状态的:所谓的无状态是指每次的请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应直接影响,也不会直接 ...
 - java-同一用户顶替操作(session过期或无效)
		
同一账号后者登录前者被强制退出:(可以通过监听器或过滤器进行监测session是否无效) 首先根据输入的用户名和密码做验证,通过验证查询用户信息.在用户信息不为空的前提下,比较静态变量中的sessio ...
 - Asp.net MVC Session过期异常的处理
		
一.使用MVC中的Filter来对Session进行验证 (1)方法1: public class MyAuthorizeAttribute : FilterAttribute, IAuthoriza ...
 
随机推荐
- eclipse中报错:Errors running builder “Integrated External Tool Builder” on project
			
在eclipse构建项目的时候,一直报如下错误: Errors during build. Errors running builder "Integrated External Tool ...
 - linux apt-get 源配置
			
linux中apt-get不能使用可能因为源不对,需要修改/etc/apt下的sources.list文件 apt-get源网上有很多,但是试了很多都不能用,以下提供一个我自己这边使用成功的源: de ...
 - mysql关联删除
			
<delete id="deleteBatchUserOfSp" parameterType="java.lang.String" > delete ...
 - C#的FTP上传下载的实验
			
前段时间做了一个FTP操作服务器文件的实验,现在把一些经验写下来,免得忘记. 1.上传的处理:目标文件夹A上传到服务器指定目录.先检索服务器目录中有无同名文件夹,若有,则先改名,上传成功后再删除,上传 ...
 - VR电影这一新概念在中国电影道路上的探索
			
在12月的一个下午,Kevin Geiger正在进行关于VR中的故事讲述的一次再普通不过的演讲.地点是北京电影学院里一个围的水泄不通的场馆,他鼓励大家都来参与电影制作,无论是导演.演员还是电影行业的任 ...
 - 如何写兼容浏览器和Node.js环境的Javascript代码
			
如果有打开过jQuery的源码(从1.11及以后),或者Vue.js.React.js的源码,都会在文件的前面看见这样一段代码: ( function( global, factory ) { &qu ...
 - mysql数据一致性检查及修复
			
percona-toolkit-2.2.20-1.noarchmysql 5.6.29-logmaster:192.168.166.129slave:192.168.166.131 一.创建数据库校验 ...
 - trove命令翻译(上)(只做翻译,未实验效果)
			
The trove client is the command-line interface (CLI) for the Database service API and its extensions ...
 - String.split()分割字符串
			
string.split(s[, sep[, maxsplit]]) Return a list of the words of the string s. If the optional secon ...
 - SpringMVC Memcached 搭建WEB项目缓存框架
			
最近做的项目一直在使用memcached作为缓存来缓存各种数据,现在BOSS要在项目上加上缓存.并把任务交给我.便琢磨怎么解决这个问题. 看了很多文章,写的比较详尽靠谱的就是这篇了http://www ...