java 过滤器Filter
一、首先在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的更多相关文章
- java 过滤器(Filter)与springMVC 拦截器(interceptor)的实现案例
java 过滤器Filter: package com.sun.test.aircraft.filter;import javax.servlet.*;import java.io.IOExcepti ...
- java过滤器Filter笔记
一.Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术之一,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp,Servlet, 静 ...
- java 过滤器Filter中chain.doFilter()之前和之后代码的执行顺序
过滤器拦截到响应url的请求后会先执行doFilter()方法中chain.doFilter()之前的代码,然后执行下一个过滤器或者servelt.紧接着执行chain.doFilter()之后的代码 ...
- XSS过滤JAVA过滤器filter 防止常见SQL注入
Java项目中XSS过滤器的使用方法. 简单介绍: XSS : 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩 ...
- java过滤器filter使用
一:filter:过滤器,拦截servlet的请求和响应. 1. package jd.com.filter; import javax.servlet.*; import java.io.IOExc ...
- 防止常见XSS 过滤 SQL注入 JAVA过滤器filter
XSS : 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶意攻击者往W ...
- java 过滤器filter使用案例
主要需要 过滤器类 和配置文件 1.过滤器类 SessionFilter package com.service; import javax.servlet.*; import javax.serv ...
- Java过滤器—Filter用法简介
一.什么是Filter? Filter译为过滤器. 由于年,Sun公司在Servlet2.3规范中添加了Filter功能,并在Servlet2.4中对Filter进行了细节上的补充. 二.运行原理: ...
- Java 过滤器Filter,Java Filter 不拦截某些请求 Java 过滤器支持Ajax请求
================================ ©Copyright 蕃薯耀 2020-01-10 https://www.cnblogs.com/fanshuyao/ 一.Java ...
- Java过滤器Filter使用详解
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6374212.html 在我的项目中有具体应用:https://github.com/ygj0930/Coupl ...
随机推荐
- windows系统版本号
windows操作系统版本号 操作系统 版本号 Windows8.1 6.3 Windows8 6.2 Windows7 6.1 Windows Server 2008 R2 6.1 Windows ...
- Sublime Text实用小技巧
1.输入"!"或"html:5",然后按Tab键: html:5 或!:用于HTML5文档类型 html:xt:用于XHTML过渡文档类型 html:4s:用于 ...
- iOS之开发小技巧
1.xcode如何添加快捷代码 xcode添加快捷代码 属性 2.cocoapods安装 cocoapods安装 3.iOS真机调试 真机调试 4.命令行自动打包 xcrun -sdk iphoneo ...
- 51nod1134(最长递增子序列)
题目链接: https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1134 题意: 中文题诶~ 思路: 直接暴力的话时间复杂度为 ...
- Swift - 点击事件奇偶次判断
// 按钮点击事件 func onTouchUpInside() { struct touchUpInside { static var count: Int = 0 } touchUpInside. ...
- 一、常见PHP网站安全漏洞
对于PHP的漏洞,目前常见的漏洞有五种.分别是Session文件漏洞.SQL注入漏洞.脚本命令执行漏洞.全局变量漏洞和文件漏洞.这里分别对这些漏洞进行简要的介绍. 1.session文件漏洞 Sess ...
- 弹出层提示,X秒后关闭
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD ...
- C++ 系列:继承
Copyright © 1900-2016, NORYES, All Rights Reserved. http://www.cnblogs.com/noryes/ 欢迎转载,请保留此版权声明. -- ...
- linux内核(kernel)版本号的意义
转自:http://www.cnblogs.com/jsjliuxing/archive/2011/12/01/2271182.html 在linux下有一个目录,即/usr/src/kernels/ ...
- POJ 2718 Smallest Difference【DFS】
题意: 就是说给你一些数,然后要求你使用这些数字组成2个数,然后求他们的差值最小. 思路: 我用的双重DFS做的,速度还比较快,其中有一个很重要的剪枝,若当前搜索的第二个数后面全部补零与第一个数所产生 ...