以下代码为项目期间,使用fiter过滤器控制统一编码和防止非法url进入
package com.tongtech.bjvsp.sysmng.filter;
import java.io.IOException;
import java.io.PrintWriter;
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.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.tongtech.bjvsp.sysmng.constant.ConstantServlet;
public class EncodingFilter extends HttpServlet implements Filter {
private FilterConfig filterConfig;
// Handle the passed-in FilterConfig
public void init(FilterConfig filterConfig) throws ServletException {
this.filterConfig = filterConfig;
}
// Process the request/response pair
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain filterChain) {
try {
HttpServletRequest httpRequest = (HttpServletRequest) request;
HttpServletResponse httpResponse = (HttpServletResponse) response;
boolean isValid = true;
String uriStr = httpRequest.getRequestURI();
if (uriStr.indexOf(".jsp") == -1 && uriStr.indexOf(".do") == -1) {
isValid = true;
} else if (uriStr.indexOf("login.jsp") == -1 && uriStr.indexOf("login.do") == -1
&& httpRequest.getSession().getAttribute("UserWraper") == null) {
isValid = false;
}
if (isValid) {
request.setCharacterEncoding("GBK");
filterChain.doFilter(request, response);
}
else {
request.setCharacterEncoding("GBK");
PrintWriter out = httpResponse.getWriter();
if( uriStr.indexOf("index.jsp") == -1 ) {
out.write("<script>window.parent.parent.location.href='../../login.jsp'</script>");
} else {
out.write("<script>window.parent.parent.location.href='../login.jsp'</script>");
}
}
} catch (ServletException sx) {
filterConfig.getServletContext().log(sx.getMessage());
} catch (IOException iox) {
filterConfig.getServletContext().log(iox.getMessage());
}
}
// Clean up resources
public void destroy() {
}
}
out.write内的内容为当未登录时或Session过期时通过地址栏访问应用URL时
对于页面跳转的控制
web.xml配置
<filter>
<filter-name>encodingfilter</filter-name>
<filter-class>com.tongtech.bjvsp.sysmng.filter.EncodingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>encodingfilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
分享到:
相关推荐
《JAVA 2应用编程150例》是一本旨在帮助开发者深入理解和掌握Java 2平台编程的实战型书籍。通过150个精心设计的实例,涵盖了Java编程的各个方面,包括基础语法、面向对象特性、异常处理、集合框架、多线程、I/O流、...
Java Web开发实战1200例第I卷的源码集合提供了一整套丰富的实例,旨在帮助开发者深入理解和掌握Web应用程序的开发技巧。这个压缩包包含的文件名为1-12源码,意味着它涵盖了从基础到进阶的12个不同主题或案例的源代码...
根据提供的信息,我们可以推断出该文章主要关注的是Java编程中的Filter(过滤器)概念及其应用实例。尽管具体内容部分给出的信息较为有限,但从标题、描述和标签中可以明确看出作者朱千平旨在通过一系列示例来讲解...
深入研究这些源代码将有助于我们理解和掌握Java Web开发的各个方面,从基础概念到实际应用。这不仅适合初学者积累经验,也对有经验的开发者有参考价值,因为可以从中学习到最佳实践和常见问题的解决方案。
本书深入浅出地讲解了这些核心技术,并通过100个精心设计的实例,帮助读者理解和掌握它们的实际应用。 1. **Servlet**:作为Java Web开发的基础,Servlet是处理HTTP请求的核心组件。书中会详细解释Servlet生命周期...
在实际应用中,`doFilter`方法通常会检查`HttpSession`中的用户标识或会话超时标志,如果发现用户会话无效,就将响应重定向到登录页面。例如: ```java if (session.getAttribute("username") == null || session....
通过【JavaWeb开发实战1200例源代码】,你可以逐个探索这些技术,每个实例都可能覆盖一个或多个知识点,通过动手实践,将理论知识与实际应用相结合,加深理解并提升开发技能。同时,也要注意尊重知识产权,合法使用...
《Java Web开发实战1200例下册之001-037》是一部针对Java Web开发的实践教程,涵盖了从基础到进阶的各种案例,对于初学者和经验丰富的Java Web开发者来说都是宝贵的资源。这个压缩包包含了从001到037的多个示例项目...
Java EE 是一个广泛使用的平台,它为开发分布式、多层架构的应用程序提供了丰富的服务和API。以下是基于这个项目的一些核心知识点: 1. **Java Server Pages (JSP)**:JSP 是Java EE中的视图层技术,用于创建动态...
通过对Java经典编程100例中的第39例进行分析,我们不仅了解了批处理的基本概念和技术细节,还掌握了如何在实际项目中运用这些知识。无论是对于初学者还是有经验的开发者来说,《Java经典编程100例》都是一本非常有...
Java Servlet Filter实现全站动态转静态是一种常见的优化技术,它能提高网站的访问速度和搜索引擎友好性。在本文中,我们将深入探讨这个主题,并通过实际的代码示例来理解其工作原理。 首先,Servlet Filter是Java ...
《Java Web开发实战1200例第2卷》是一本深入浅出的教程,旨在帮助读者掌握Java Web开发的核心技术和实践应用。本书通过丰富的实例,涵盖了21至23章的内容,旨在让读者在实践中学习,提升技能。以下是根据这些章节...
【JAVA编程百例71】这个压缩包涵盖了多个JAVA编程的实际应用示例,涉及了从基本图形绘制到网络通信,再到文件操作等多个方面。以下是对这些实例的详细解读: 1. **实例26 - 基本图形绘制**:这部分内容涉及到Java的...
### Java经典编程100例之第14例:使用forEach进行数组或集合遍历 #### 背景介绍 在Java开发过程中,数组和集合是程序员经常使用的数据结构之一。随着Java 8及后续版本的发布,新的流式处理方式(Stream API)和...
在实际应用中,Java Servlet的实例通常包括以下步骤: 1. **创建Servlet类**:继承自`javax.servlet.http.HttpServlet`类,重写`doGet()`和`doPost()`方法来处理GET和POST类型的HTTP请求。 2. **Servlet初始化**:...
在JavaWeb实战开发中,1200例的教程涵盖了...在学习过程中,理解每个概念的实际应用场景,结合实例进行实践,是掌握JavaWeb开发的关键。通过1200例的实战,你将有机会深入学习并熟练运用这些技术,提升自己的开发技能。
Java是一种广泛使用的面向对象的编程...这些实例涵盖了Java编程的各个方面,通过实际操作,初学者能更好地理解Java的核心概念和编程技巧,从而逐步提升编程能力。在实践中不断学习和探索,是成为优秀Java开发者的关键。
标题中的"FFT_Filter.java.txt_image_"表明这是一个与图像处理相关的Java源代码文件,其中使用了快速傅里叶变换(FFT)来实现滤波功能。快速傅里叶变换是一种高效的算法,用于计算离散傅里叶变换(DFT),在信号处理...
在本例中,Servlet可能被用作过滤器(Filter),在请求到达目的地(如JSP页面)之前进行预处理,或者在响应返回客户端之前进行后处理。例如,可以使用Servlet Filter进行身份验证、日志记录或数据缓存等操作。 JSP...
Java编写的一个简单的留言板系统是基于经典的Struts框架实现的,这个框架在Web应用程序开发中扮演着重要的角色。Struts是一个开源的MVC(Model-View-Controller)框架,它为构建基于Java EE平台的Web应用提供了强大...