1.新建一个FirstFilter类代码如下:
package com.ask.filter;
import java.io.IOException;
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.HttpServletResponse;
/*自定义一个java类实现filter接口*/
public class FirstFilter implements Filter {
//通过file配置文件中修改编码方式;
private FilterConfig config;
public FirstFilter(){
System.out.println("FirstFilter: "+this.hashCode());
}
public void init(FilterConfig arg0) throws ServletException {
config=arg0;
System.out.println("init: "+this.hashCode());
}
public void doFilter(ServletRequest req, ServletResponse res,
FilterChain chain) throws IOException, ServletException {
String utf8=config.getInitParameter("utf-8");
HttpServletResponse resp=(HttpServletResponse) res;
//resp.setContentType("text/html;charset=utf-8");
resp.setContentType("text/html;charset="+utf8);
//调用下一个filter或者是web资源
chain.doFilter(req, res);
}
public void destroy() {
System.out.println("destroy: "+this.hashCode());
}
}
2.新建一个LoginFilter类代码如下:
packagecom.ask.filter;
importjava.io.IOException;
importjavax.servlet.Filter;
importjavax.servlet.FilterChain;
importjavax.servlet.FilterConfig;
importjavax.servlet.ServletException;
importjavax.servlet.ServletRequest;
importjavax.servlet.ServletResponse;
importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;
importjavax.servlet.http.HttpSession;
publicclassLoginFilterimplementsFilter {
publicvoiddoFilter(ServletRequest arg0, ServletResponse arg1,
FilterChain chain)throwsIOException, ServletException {
HttpServletRequest req=(HttpServletRequest) arg0;
HttpServletResponse res=(HttpServletResponse) arg1;
//获取资源路径;
String uri=req.getRequestURI();
//获得jsp文件名;
String action=uri.substring(uri.lastIndexOf("/")+1, uri.indexOf("."));
System.out.println(action);
if("login".equals(action)&&uri.endsWith(".jsp")) {//判断是否是longin.jsp请求
chain.doFilter(req, res);
}else{//main.jsp longin.do
if("login".equals(action)) {//如果是login.do请求
HttpSession session=req.getSession();
if(session.getAttribute("name")==null) {
String name=req.getParameter("username");
String pwd=req.getParameter("password");
if("tom".equals(name)&&"123".equals(pwd)) {
session.setAttribute("name", name);
chain.doFilter(req, res);
}else{
res.sendRedirect(req.getContextPath()+"/login.jsp");
}
}
}else{
HttpSession session=req.getSession(false);
if(session.getAttribute("name")==null) {
res.sendRedirect(req.getContextPath()+"/login.jsp");
}else{
chain.doFilter(req, res);
}
}
}
}
publicvoidinit(FilterConfig arg0)throwsServletException {
//TODOAuto-generated method stub
}
publicvoiddestroy() {
//TODOAuto-generated method stub
}
}
3.新建一个SecFilter类,代码如下:
package com.ask.filter;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class SecFilter implements Filter {
public void destroy() {
System.out.println("sec---destroy");
}
public void doFilter(ServletRequest req, ServletResponse res,
FilterChain chain) throws IOException, ServletException {
chain.doFilter(req, res);
}
public void init(FilterConfig arg0) throws ServletException {
System.out.println("sec---init");
}
}
4.新建一个showServlet类代码如下:
package com.ask.servlet;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class showServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException {
String name=req.getParameter("username");
System.out.println("service");
res.getWriter().write("演示servlet中的filter过滤器");
HttpSession session=req.getSession();
session.setAttribute("name", name);
System.out.println("登录成功");
res.sendRedirect(req.getContextPath()+"/main.jsp");
}
}
5.在WebRoot目录下新建两个jsp文件,分别是login.jsp和main.jsp文件
Login.jsp如下
<%@ page language="java"contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type"content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<form action="${pageContext.request.contextPath }/login.do"method="post">
username:<input type="text"name="username">
password:<input type="password"name="password">
<input type="submit"value="longing">
</form>
</body>
</html>
Main.jsp如下:
<%@ page language="java"contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type"content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
欢迎 ${name}进入主页面
</body>
</html>
6.在web.xml配置文件中配置如下:
<?xml version="1.0"encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://java.sun.com/xml/ns/javaee"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"id="WebApp_ID"version="3.0">
<display-name>firstServlet</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<!-- 测试LoginFilter -->
<filter>
<filter-name>first</filter-name>
<filter-class>com.ask.filter.LoginFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>first</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<servlet>
<servlet-name>show</servlet-name>
<servlet-class>com.ask.servlet.showServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>show</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
</web-app>
分享到:
相关推荐
过滤器可以用来实现诸如登录验证、数据转换、日志记录等功能,为Web应用程序提供了强大的扩展性。 首先,我们需要理解过滤器的基本工作原理。当用户向服务器发送一个请求时,过滤器会按照在web.xml中的配置顺序被...
下面我们就通过分析一个具体的示例代码来详细了解如何使用JSP Filter过滤器来判断用户是否已经登录。 #### 示例代码分析 首先,我们来看一下示例中的过滤器类`RightFilter`: ```java import javax.servlet....
在这个例子中,过滤器的主要任务是对每个请求进行登录验证。如果用户未登录,过滤器将拦截请求并重定向到登录页面。一旦用户成功登录,通常会将用户信息(如用户名或ID)存储在会话(session)中。 3. **Session和...
* 认证和授权:可以使用 Filter 来实现认证和授权功能,例如检查用户的登录状态和权限。 * 日志记录:可以使用 Filter 来记录客户端的请求和响应信息,以便进行日志记录和分析。 * 缓存处理:可以使用 Filter 来实现...
在"使用过滤器完成用户登录验证"的场景中,我们将创建一个过滤器类,该类实现了Filter接口并重写了doFilter()方法。在这个方法里,我们可以检查请求中是否有有效的登录信息,例如通过检查请求头中的session或cookie...
在这个项目中,“jsp+servlet登录验证过滤器”涉及了用户登录验证的过程,以及使用过滤器(Filter)来实现这一功能。下面将详细介绍这个主题中的相关知识点。 1. **JSP**:JSP是一种服务器端的技术,允许开发者在...
在这个场景下,我们讨论的是如何使用过滤器来实现用户登录验证的功能。下面将详细解释这一过程。 首先,我们需要了解过滤器的基本概念。在Java Web应用中,过滤器是实现了javax.servlet.Filter接口的类。它们通过在...
在这个场景中,我们将探讨如何利用授权过滤器来验证用户的登录状态。 首先,了解.NET MVC过滤器的基本概念。过滤器在.NET MVC中扮演着拦截器的角色,可以应用于控制器或特定的动作,执行预处理和后处理任务。主要有...
在Java Web开发中,`Filter`过滤器是一个关键的安全组件,用于拦截并处理HTTP请求和响应。本示例中的`URLfilter`类就是一个简单的过滤器,它的主要目的是防止SQL注入攻击,这是一种常见的恶意攻击手段,攻击者试图...
在本例中,要实现一个简单的登录验证过滤器,可以阻止未登录用户访问除了登录页面以外的其他后台管理页面。通过实现javax.servlet.Filter接口,我们创建了一个LoginFilter类。这个过滤器会在每个请求到达目标页面...
在IT领域,特别是Java Web开发中,Servlet过滤器(Filter)是实现用户权限管理、登录状态验证等关键功能的重要机制之一。本文将深入探讨如何利用Servlet过滤器来验证用户是否已登录,以及如何配置过滤器以针对特定的...
过滤器可以用于执行诸如数据校验、身份验证、字符编码转换、日志记录等多种任务,提高了代码的可复用性和模块化。 ### 二、过滤器的工作原理 过滤器的工作流程遵循以下步骤: 1. 用户发起HTTP请求。 2. 服务器...
在这个"过滤器验证用户登录"项目中,我们关注的是如何利用过滤器来实现用户身份的验证,确保只有已登录的用户才能访问特定的Web资源。这个项目结合了IntelliJ IDEA这一强大的Java开发工具,为开发者提供了高效且专业...
在这个例子中,首先检查是否存在名为“email”的GET参数,然后使用`FILTER_VALIDATE_EMAIL`过滤器验证其是否为有效邮箱地址。 总的来说,PHP Filter过滤器是处理和验证输入数据的关键工具,确保数据安全性和应用的...
在标题提到的"filter过滤器的简单使用.rar"压缩包中,很显然包含了一个关于如何在Maven项目和Spring Boot项目中使用Filter的示例。下面将详细介绍Filter的基本概念、工作原理以及如何在两种项目环境中应用。 **...
【Java Filter过滤器详解】 Java Filter是Java Servlet技术的一部分,它允许开发者在Servlet容器中对HTTP请求和响应进行拦截处理,实现数据过滤、权限控制、日志记录等多种功能。Filter的生命周期包括三个主要方法...
Filter 有多种应用场景,例如禁用页面缓存、字符编码过滤器、身份验证过滤器等。禁用页面缓存的过滤器可以通过设置 response 的头信息来禁用缓存,例如设置 Expires、Cache-Control、Pragma 等头信息。 字符编码...
Filter过滤器处理则是在数据传输或处理流程中添加的一层逻辑,用于拦截、修改或者增强数据。 首先,我们来深入理解Socket通信。Socket可以视为网络上的两个程序之间的一个连接点,通过这个连接点,数据可以在它们...