用过滤器Filter判断用户是否登陆

WEB.XML

  1. <!-- 用户session的 键   sessionKEY -->
  2. <context-param>
  3. <param-name>userSessionKey</param-name>
  4. <param-value>USERSESSIONKEY</param-value>
  5. </context-param>
  6. <!-- 重定向的页面 -->
  7. <context-param>
  8. <param-name>rediretPage</param-name>
  9. <param-value>/u_member/Login.jsp</param-value>
  10. </context-param>
  11. <!-- 不需要过滤的页面 -->
  12. <context-param>
  13. <param-name>uncheckUrls</param-name>
  14. <param-value>/u_member/insert.jsp,/u_member/Login.jsp</param-value>
  15. </context-param>

Filter 过滤器代码

  1. package go.onlineShop.filter;
  2. import java.io.IOException;
  3. import java.util.Arrays;
  4. import java.util.List;
  5. import javax.servlet.Filter;
  6. import javax.servlet.FilterChain;
  7. import javax.servlet.FilterConfig;
  8. import javax.servlet.ServletException;
  9. import javax.servlet.ServletRequest;
  10. import javax.servlet.ServletResponse;
  11. import javax.servlet.annotation.WebFilter;
  12. import javax.servlet.http.HttpServletRequest;
  13. import javax.servlet.http.HttpServletResponse;
  14. /**
  15. * Servlet Filter implementation class IsLoginFilter
  16. * 判断是否登陆过滤器
  17. */
  18. @WebFilter("/u_member")
  19. public class IsLoginFilter implements Filter {
  20. //从xml中取值
  21. String uncheckUrls =null;
  22. String userSessionKey=null;
  23. String rediretPage=null;
  24. /**
  25. * Default constructor.
  26. */
  27. public IsLoginFilter() {
  28. // TODO Auto-generated constructor stub
  29. }
  30. /**
  31. * @see Filter#destroy()
  32. */
  33. public void destroy() {
  34. // TODO Auto-generated method stub
  35. }
  36. /**
  37. * @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain)
  38. */
  39. public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
  40. // TODO Auto-generated method stub
  41. //1.得到访问路径
  42. HttpServletRequest request = (HttpServletRequest)req;
  43. HttpServletResponse response = (HttpServletResponse)res;
  44. String reqUrl = request.getRequestURL().toString();
  45. String reqURI = request.getRequestURI();
  46. String servletPath = request.getServletPath();
  47. //  String[] uncheckUrl = uncheckUrls.split(",");
  48. List<String> urls = Arrays.asList(uncheckUrls.split(","));
  49. //2.如果是属于不需要过滤的地址就直接  放行  方法结束
  50. if(urls.contains(servletPath)){
  51. chain.doFilter(request, response);
  52. return;
  53. }
  54. //3.从session中获取sessionKey对应的值;若不存在  则跳转到登陆页面
  55. Object user = request.getSession().getAttribute(userSessionKey);
  56. if(user==null){
  57. request.getRequestDispatcher(rediretPage).forward(request, response);
  58. return;
  59. }
  60. //4若存在 则放行;
  61. chain.doFilter(request, response);
  62. }
  63. /**
  64. * @see Filter#init(FilterConfig)
  65. */
  66. public void init(FilterConfig fConfig) throws ServletException {
  67. rediretPage=fConfig.getServletContext().getInitParameter("rediretPage");
  68. uncheckUrls=fConfig.getServletContext().getInitParameter("uncheckUrls");
  69. userSessionKey=fConfig.getServletContext().getInitParameter("userSessionKey");
  70. }
  71. }

Login页面

参考:

用过滤器Filter判断用户是否登陆 - CSDN博客
http://blog.csdn.net/u010634066/article/details/38769577

用过滤器Filter判断用户是否登陆的更多相关文章

  1. .Net Mvc判断用户是否登陆、未登陆跳回登陆页、三种完美解决方案

    开篇先不讲解,如何判断用户是否登陆,我们先来看用户登录的部分代码,账户密码都正确后,先将当前登录的用户名记录下来. public ActionResult ProcessLogin() { try { ...

  2. 2016-02-20WebForm登陆验证,判断用户是否登陆 PageBase类

    http://blog.csdn.net/fanbin168/article/details/49404233 很多时候,WebFrom页面,我们需要判断用户是否已经登陆了.假如有很多页面,难道我们要 ...

  3. Ecshop在模板中判断用户是否登陆,获取用户等级信息

    ecshop模板中smarty怎样判断用户等级.用户id.用户昵称用户名,请看以下方法,使用全局变量 <!-- {if $smarty.session.user_rank gt 1}--> ...

  4. django 判断用户是否登陆

    基于类的视图登陆

  5. JavaEE中Filter实现用户登录拦截

    实现思路是编写过滤器,如果用户登录之后session中会存一个user.如果未登录就为null,就可以通过过滤器将用户重定向到登陆页面,让用户进行登陆,当然过滤器得判断用户访问的如果是登陆请求需要放行 ...

  6. servlet和jsp页面过滤器Filter的作用及配置

    刚刚有个朋友问我,Servlet的过滤器有什么作用? 现在发个帖子说明一下,            过滤器是一个对象,可以传输请求或修改响应.它可以在请求到达Servlet/JSP之前对其进行预处理, ...

  7. 在写WebApi判断用户权限时返回数据和接受支付结果 定义返回数据类型

    using ADT.Core.Encrypt; using System; using System.Collections.Generic; using System.Linq; using Sys ...

  8. 【Filter 不登陆无法访问】web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面的功能

    在web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面,而重定向到登陆界面的功能. 项目是用springMVC+spring+hibernate实现 (和这个没有多大关系) 第一步: 首先 ...

  9. 过滤器(Filter)案例:检测用户是否登陆的过滤器

    *****检测用户是否登陆的过滤器:不需要用户跳转到每个页面都需要登陆,访问一群页面时,只在某个页面上登陆一次,就可以访问其他页面: 1.自定义抽象的 HttpFilter类, 实现自 Filter ...

随机推荐

  1. webservice学习第二天

    1 课程回顾 l 什么是webservice 远程调用技术:系统和系统之间的调用,获取远程系统里的业务数据 Webservice使用http传输SOAP协议的数据的一种远程调用技术 l Webserv ...

  2. INFO main org.springframework.context.support.AbstractApplicationContext

    原因, spring-framework-5.0.2.RELEASE  需要使用 jdk8.

  3. [HAOI2006]受欢迎的牛(tarjan缩点)

    洛谷传送门 直接tarjan求scc,然后统计出度为0的缩点,如果多余1个就输出0,只有一个就输出这个缩点里的点. ——代码 #include <cstdio> #include < ...

  4. ajax请求数据之后在已经有的数据前面打对勾的方法

    今天遇到这么一个需求: 选择一部分人,在点击确定的时候添加到对应的div中,也就是添加到对应的表单下面,当再次查询的时候需要在已经选过的人的复选框前面打伤对勾.

  5. java容器详解(以Array Arrays ArrayList为例)

    //先记录一个想法……java实在是太臃肿了,纯面向对象也有不少弊端…… //能不能把java精简一下啊! 先上结论: Array:认真看api索引的话,Array有两个.一个是sql中的接口,一个是 ...

  6. CodeForces 593A 2Char

    暴力. #include<cstdio> #include<cstring> #include<cmath> #include<algorithm> u ...

  7. HDU 3938

    并查集的离线算法. 题意是大坑.理解为寻找两点之间所有路径中的最长的边的值小于输入的值的点对的个数. 直接来代码. #include<stdio.h> #include<iostre ...

  8. hdu6215 Brute Force Sorting(模拟)

    题意 给一个长度为n(n<=1e5)的序列,如果一个位置i满足a[i-1]>a[i]或者a[i]>a[i+1],那么我们就称该位置是不合法的位置 先把序列中所有不合法的位置统一找出来 ...

  9. Java并发包——线程安全的Collection相关类

    Java并发包——线程安全的Collection相关类 摘要:本文主要学习了Java并发包下线程安全的Collection相关的类. 部分内容来自以下博客: https://www.cnblogs.c ...

  10. 【SQL Server 学习系列】-- ConnectionTimeout、CommandTimeout和BulkCopyTimeout

    1. SqlConnection.ConnectionTimeout获取在尝试建立连接时终止尝试并生成错误之前所等待的时间.单位:秒默认值:15秒设置为0时,表示无限制 2. SqlCommand.C ...