一、首先在web.xml里进行拦截过滤

  <filter>
        <filter-name>platformServiceAgreementFilter</filter-name>
        <filter-class>com.yingle.web.lawyer.filter.PlatformServiceAgreementFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>platformServiceAgreementFilter</filter-name>
        <url-pattern>/faces/pc/secure/v/*</url-pattern>
    </filter-mapping>
    <filter-mapping>
        <filter-name>platformServiceAgreementFilter</filter-name>
        <url-pattern>/faces/mobile/secure/v/*</url-pattern>
    </filter-mapping>

二、在com.yingle.web.lawyer.filter.PlatformServiceAgreementFilter包里处理响应

PlatformServiceAgreementFilter extends HttpFilter

/**
     *
     */
    @Override
    public void doFilter(HttpServletRequest request, HttpServletResponse response, HttpSession session,
        FilterChain chain) throws ServletException, IOException {
        Integer userProfileId = LoggedUserUtil.getLoggedUserProfileId();
        try {
            LawyerProfile lawyer = null;
            if (null != userProfileId) {
                lawyer = lawyerProfileService.getById(userProfileId);
            }
            Page page = pageConfig.getLatest(PageConfig.PLATFORM_SERVICE_AGREEMENT);
            if (null != lawyer && null != page) {
                Date publishTime = page.getPublishTime();
                if (null == lawyer.getAcceptServiceAgreementTime()
                    || lawyer.getAcceptServiceAgreementTime().compareTo(publishTime) <= 0) {
                    String userAccessEnvironment = FacesEnvironmentContextListener.getUserAccessEnvironment(request);
                    String originRequesetURL = request.getRequestURL().toString();
                    String queryString = request.getQueryString();

if (StringUtil.isNotEmpty(queryString)) {
                        if (queryString.indexOf("faces-redirect") >= 0) {
                            originRequesetURL = originRequesetURL + "?" + queryString;
                        } else {
                            originRequesetURL = originRequesetURL + "?faces-redirect=true&" + queryString;
                        }
                    } else {
                        originRequesetURL = originRequesetURL + "?faces-redirect=true";
                    }

session.setAttribute(SessionKey.REQUEST_URL_BEFORE_AGREEMENT_KEY, originRequesetURL);

String redirectPagePath =
                        request.getContextPath()
                            + String.format(PLATFORM_SERVICE_AGREEMENT_URL, userAccessEnvironment);
                    ServletUtil.redirect(response, redirectPagePath);
                }
            }
        } catch (ApplicationServiceException e) {
            throw new ServletException("encounter error while showing platform service agreement", e);
        }
        chain.doFilter(request, response);
    }

java 过滤器Filter的更多相关文章

  1. java 过滤器(Filter)与springMVC 拦截器(interceptor)的实现案例

    java 过滤器Filter: package com.sun.test.aircraft.filter;import javax.servlet.*;import java.io.IOExcepti ...

  2. java过滤器Filter笔记

    一.Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术之一,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp,Servlet, 静 ...

  3. java 过滤器Filter中chain.doFilter()之前和之后代码的执行顺序

    过滤器拦截到响应url的请求后会先执行doFilter()方法中chain.doFilter()之前的代码,然后执行下一个过滤器或者servelt.紧接着执行chain.doFilter()之后的代码 ...

  4. XSS过滤JAVA过滤器filter 防止常见SQL注入

    Java项目中XSS过滤器的使用方法. 简单介绍: XSS : 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩 ...

  5. java过滤器filter使用

    一:filter:过滤器,拦截servlet的请求和响应. 1. package jd.com.filter; import javax.servlet.*; import java.io.IOExc ...

  6. 防止常见XSS 过滤 SQL注入 JAVA过滤器filter

    XSS : 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶意攻击者往W ...

  7. java 过滤器filter使用案例

    主要需要 过滤器类  和配置文件 1.过滤器类 SessionFilter package com.service; import javax.servlet.*; import javax.serv ...

  8. Java过滤器—Filter用法简介

    一.什么是Filter? Filter译为过滤器. 由于年,Sun公司在Servlet2.3规范中添加了Filter功能,并在Servlet2.4中对Filter进行了细节上的补充. 二.运行原理: ...

  9. Java 过滤器Filter,Java Filter 不拦截某些请求 Java 过滤器支持Ajax请求

    ================================ ©Copyright 蕃薯耀 2020-01-10 https://www.cnblogs.com/fanshuyao/ 一.Java ...

  10. Java过滤器Filter使用详解

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6374212.html 在我的项目中有具体应用:https://github.com/ygj0930/Coupl ...

随机推荐

  1. 【日记】搭建一个node本地服务器

    用node搭建一个本地http服务器.首先了解htpp服务器原理 HTTP协议定义Web客户端如何从Web服务器请求Web页面,以及服务器如何把Web页面传送给客户端.HTTP协议采用了请求/响应模型 ...

  2. 显示或隐藏div

    代码来源于博客,如有侵权,请联系我! ASP.NET中TextBox控件设置ReadOnly="true"H或Enabled=false后台取不到值 当TextBox设置了Read ...

  3. CString转换为string

    string CStringToString(CString strMFC) { CStringA strA; strA = strMFC.GetBuffer(); strMFC.ReleaseBuf ...

  4. mysql 创建用户、授权等操作

    一, 创建用户: 命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 说明:username - 你将创建的用户名, host - 指 ...

  5. ios htttp网络请求cookie的读取与写入(NSHTTPCookieStorage)

    当你访问一个网站时,NSURLRequest都会帮你主动记录下来你访问的站点设置的Cookie,如果 Cookie 存在的话,会把这些信息放在 NSHTTPCookieStorage 容器中共享,当你 ...

  6. java常见的问题

    1.   接口与抽象类的区别? 抽象类:含有abstract修饰的class即为抽象类abstract类不能创建实例对象,不能有抽象的构造方法或抽象的静态方法,如果子类没有实现抽象父类中的所有 方法, ...

  7. 【转】理解 PHP 依赖注入 | Laravel IoC容器

    Laravel框架的依赖注入确实很强大,并且通过容器实现依赖注入可以有选择性的加载需要的服务,减少初始化框架的开销,下面是我在网上看到的一个帖子,写的很好拿来与大家分享,文章从开始按照传统的类设计数据 ...

  8. XML带多属性解析为一个实体类(利用反射)

    最近在对接一个银行的项目,大概就是类似一个钱包的功能,在请求返回的数据时,发现返回的数据标准的XML格式的支付串,格式如下 <kColl id="inputOrig" app ...

  9. 安装storm的一些很乱的笔记

    下面是自己安装和测试storm的一些笔记,比较乱,后续有时间在整理一篇. storm jar all-my-code.jar com.storm.MyTopology arg1 arg2这个命令会运行 ...

  10. Unity中无GC Alloc的CalculateFrustumPlanes

    如果你需要在逻辑层做一些预先的剔除操作,可能需要从MainCamera构建视锥体,然后进行简易相交测试,这时候在unity里面用到的函数接口是CalculateFrustumPlanes: names ...