web xml

  1. <filter>
  2.    <filter-name>DelegatingFilterProxy</filter-name>
  3.    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
  4.    <init-param>
  5.      <param-name>targetFilterLifecycle</param-name>
  6.      <param-value>true</param-value>
  7.    </init-param>
  8.    <init-param>
  9.      <param-name>targetBeanName</param-name>
  10.      <param-value>autoLoginfilter</param-value>
  11.    </init-param>
  12.  </filter>

配置自动扫描注解

  1. <context:component-scan base-package="cn.com.do1.important.filter" />

filter

  1. package cn.com.do1.important.filter;
  2. import cn.com.do1.component.common.util.ValidateUtil;
  3. import cn.com.do1.dqdp.core.DqdpAppContext;
  4. import cn.com.do1.important.service.IAuthService;
  5. import cn.com.do1.wechat.aes.AesException;
  6. import cn.com.do1.wechat.aes.WXBizMsgCrypt;
  7. import cn.com.do1.wechat.basic.WeChatReqsUTLCfg;
  8. import cn.com.do1.wechat.common.ConfKit;
  9. import cn.com.do1.wechat.common.RequestUtil;
  10. import cn.com.do1.wechat.common.Tools;
  11. import cn.com.do1.wechat.core.WeChatCore;
  12. import org.apache.struts2.ServletActionContext;
  13. import org.slf4j.Logger;
  14. import org.slf4j.LoggerFactory;
  15. import org.springframework.stereotype.Component;
  16. import org.springframework.web.context.WebApplicationContext;
  17. import org.springframework.web.context.support.WebApplicationContextUtils;
  18. import org.springframework.web.filter.OncePerRequestFilter;
  19. import javax.annotation.Resource;
  20. import javax.servlet.*;
  21. import javax.servlet.http.Cookie;
  22. import javax.servlet.http.HttpServletRequest;
  23. import javax.servlet.http.HttpServletResponse;
  24. import javax.servlet.http.HttpSession;
  25. import java.io.IOException;
  26. import java.net.CookieManager;
  27. import java.util.HashMap;
  28. import java.util.Map;
  29. /**
  30. * 请求拦截
  31. *
  32. * @author ao.ouyang
  33. */
  34. @Component("autoLoginfilter")
  35. public class AutoLoginFilter extends OncePerRequestFilter {
  36.    private final Logger log = LoggerFactory.getLogger(AutoLoginFilter.class);
  37.    @Resource
  38.    private IAuthService authService;
  39.    @Override
  40.    protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
  41.        try {
  42.            HttpSession session = request.getSession(true);
  43.            String username = null;
  44.            String password = null;   // 此sessionid是上次用户登录时保存于用户端的识别码,用于用户后续访问的自动登录。不是本次访问的session id。
  45.            Cookie[] cookies;
  46.            // 如果session中没有user对象,则创建一个。
  47.            Map user = (Map) session.getAttribute("_user");
  48.            if (user == null) {
  49.                user = new HashMap(); // 此时user中的username属性为"",表示用户未登录。
  50.            }
  51.            // 如果user对象的username为"",表示用户未登录。则执行自动登录过程。
  52.            // 否则不自动登录。
  53.            if (ValidateUtil.isNullOrBlank(user.get("USER_NAME"))) {
  54.                cookies = request.getCookies();
  55.                for (Cookie cookie : cookies){
  56.                    if(cookie.getName().equalsIgnoreCase("SESSION_LOGIN_USERNAME")){
  57.                        username = cookie.getValue();
  58.                    }
  59.                    if(cookie.getName().equalsIgnoreCase("SESSION_LOGIN_PASSWORD")){
  60.                        password = cookie.getValue();
  61.                    }
  62.                }
  63.                if(!ValidateUtil.isNullOrBlank(username) && !ValidateUtil.isNullOrBlank(password)){
  64.                    if(authService.validUser(username,password).equalsIgnoreCase("successful")){
  65.                        user = authService.viewPersonByUserName(username);
  66.                        authService.updateUserLog(user);
  67.                        ServletActionContext.getRequest().getSession().setAttribute("_user", user);
  68.                    }
  69.                }
  70.            }
  71.        }catch (Exception e){
  72.            log.error(e.getMessage(),e);
  73.        }
  74.    }
  75. }

spring filter 配置的更多相关文章

  1. Spring Boot 2 使用Servlet、Listener和Filter配置

    开发环境:IntelliJ IDEA 2019.2.2Spring Boot版本:2.1.8 新建一个名称为demo的Spring Boot项目. 一.使用Servlet配置 1.修改启动类 Demo ...

  2. spring filter过滤器

    1.简介 Filter也称之为过滤器,它是Servlet技术中最实用的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 ...

  3. springMVC用法 以及一个简单的基于springMVC hibernate spring的配置

    替代struts 1  web.xml中配置springmvc中央控制器 <?xml version="1.0" encoding="UTF-8"?> ...

  4. spring filter lister servlet

    https://blog.csdn.net/nacey5201/article/details/8547772 https://blog.csdn.net/xwl617756974/article/d ...

  5. spring boot 之 spring security 配置

    Spring Security简介 之前项目都是用shiro,但是时过境迁,spring security变得越来越流行.spring security的前身是Acegi, acegi 我也玩过,那都 ...

  6. 最小可用 Spring MVC 配置

    [最小可用 Spring MVC 配置] 1.导入有概率用到的JAR包, -> pom.xml 的更佳实践 - 1.0 <- <project xmlns="http:// ...

  7. spring下配置shiro

    1.web.xml中加入shiro的过滤器: <!-- Spring --> <!-- 配置Spring配置文件路径 --> <context-param> < ...

  8. Tomcat配置和Spring MVC配置

    Tomcat启动时,先找系统变量CATALINA_BASE,如果没有,则找CATALINA_HOME.然后找这个变量所指的目录下的conf文件夹,从中读取配置文件.最重要的配置文件:server.xm ...

  9. Spring Boot配置过滤器的两种方式

    过滤器(Filter)是Servlet中常用的技术,可以实现用户在访问某个目标资源之前,对访问的请求和响应进行拦截,常用的场景有登录校验.权限控制.敏感词过滤等,下面介绍下Spring Boot配置过 ...

随机推荐

  1. 蛋疼的经历--wireshark不能启动的问题

    事情是这样子的,最近新入职,安装了wireshark,,,在急需要其观察数据包结构,,,,写代码时,,,,卡了,,,我的天!!! 刚开始是提示说,找不到动态链接库api-ms-win-crt-runt ...

  2. 我收藏的技术知识图(每张都是大图)关于XX背后的知识、技术图,例如:Linux、Nginx架构、PHP知识卡、机会、HTML5移动、Android系统架构、YII架构的典型流程、Css知识表

    我收藏的技术知识图(每张都是大图) HTML5Linux/Unix系统设计思想读书笔记 LinuxMVCJava线程MVCSpring MVCCSS3Nginx架构VimCliCommandsPHP知 ...

  3. [企业化NET]Window Server 2008 R2[2]-SVN 服务端 和 客户端 安装

    1.  服务器基本安装即问题解决记录      √ 2.  SVN环境搭建和客户端使用 2.1  服务端 和 客户端 安装    √ 2.2  项目建立与基本使用     √ 2.3  基本冲突解决, ...

  4. WSAAsyncSelect模型触发不了FD_Close消息?

    原帖链接: http://bbs.csdn.net/topics/330164174 楼主: Server用WSAAsyncSelect模型,Client关闭程序时(不进行shutdown与close ...

  5. 两张图看清SharePoint 2013 Farm 逻辑体系结构

    前篇文章分析了SharePoint 2013 的物理拓扑结构.物理拓扑分为3层(2层),详情参见<SharePoint 2013 Farm (多层服务器)安装指南——Least Privileg ...

  6. CentOS 7安装Redis4.0.10

    cd /usr/local/src && wget http://download.redis.io/releases/redis-4.0.10.tar.gz && t ...

  7. nodejs 遍历文件夹下所有的图片改名为中文

    安装依赖 $ npm init -y && npm i fs-extra globby request -S main.js const fs = require('node-fs-e ...

  8. CSS中易忽略的点

    一.使用斜杠/分割的关键字 1.font H2{ font:12px/100% sans-serif; } 分割的分别是 字体大小 与 行高 ,其他关键是用空白符分割. 2.background di ...

  9. 码字工作者的发文姿势—— 用MWeb+Markdown Here+七牛 轻松实现多平台发布

    码字工作者的发文姿势—— 用MWeb+Markdown Here+七牛 轻松实现多平台发布   1.对于写作你最头疼什么 对于大多数码字工作者来说,随时随地记录灵感,构思文章,集中书写,其实是一件令人 ...

  10. centos 6.3 64位下cpuminer +mining_proxy 挖掘莱特币(LTC)教程

    1.下载软件: cpuminer: http://sourceforge.net/projects/cpuminer/files/ 找到对应的版本,我的服务器是centos64的,找了个当前最高版本: ...