`
吕金含
  • 浏览: 88093 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

filter过滤器登录验证

 
阅读更多

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>

分享到:
评论

相关推荐

    过滤器(Filter)

    过滤器可以用来实现诸如登录验证、数据转换、日志记录等功能,为Web应用程序提供了强大的扩展性。 首先,我们需要理解过滤器的基本工作原理。当用户向服务器发送一个请求时,过滤器会按照在web.xml中的配置顺序被...

    jsp filter 过滤器判断用户是否登录

    下面我们就通过分析一个具体的示例代码来详细了解如何使用JSP Filter过滤器来判断用户是否已经登录。 #### 示例代码分析 首先,我们来看一下示例中的过滤器类`RightFilter`: ```java import javax.servlet....

    servlet 过滤器做的简单登陆demo

    在这个例子中,过滤器的主要任务是对每个请求进行登录验证。如果用户未登录,过滤器将拦截请求并重定向到登录页面。一旦用户成功登录,通常会将用户信息(如用户名或ID)存储在会话(session)中。 3. **Session和...

    Filter(过滤器)简介和工作原理

    * 认证和授权:可以使用 Filter 来实现认证和授权功能,例如检查用户的登录状态和权限。 * 日志记录:可以使用 Filter 来记录客户端的请求和响应信息,以便进行日志记录和分析。 * 缓存处理:可以使用 Filter 来实现...

    使用过滤器完成用户登录验证

    在"使用过滤器完成用户登录验证"的场景中,我们将创建一个过滤器类,该类实现了Filter接口并重写了doFilter()方法。在这个方法里,我们可以检查请求中是否有有效的登录信息,例如通过检查请求头中的session或cookie...

    jsp+servlet登录验证过滤器

    在这个项目中,“jsp+servlet登录验证过滤器”涉及了用户登录验证的过程,以及使用过滤器(Filter)来实现这一功能。下面将详细介绍这个主题中的相关知识点。 1. **JSP**:JSP是一种服务器端的技术,允许开发者在...

    使用过滤器实现判断用户是否登录验证.

    在这个场景下,我们讨论的是如何使用过滤器来实现用户登录验证的功能。下面将详细解释这一过程。 首先,我们需要了解过滤器的基本概念。在Java Web应用中,过滤器是实现了javax.servlet.Filter接口的类。它们通过在...

    .NET MVC授权过滤器验证登录

    在这个场景中,我们将探讨如何利用授权过滤器来验证用户的登录状态。 首先,了解.NET MVC过滤器的基本概念。过滤器在.NET MVC中扮演着拦截器的角色,可以应用于控制器或特定的动作,执行预处理和后处理任务。主要有...

    filter过滤器防止恶意注入

    在Java Web开发中,`Filter`过滤器是一个关键的安全组件,用于拦截并处理HTTP请求和响应。本示例中的`URLfilter`类就是一个简单的过滤器,它的主要目的是防止SQL注入攻击,这是一种常见的恶意攻击手段,攻击者试图...

    servlet+jsp实现过滤器 防止用户未登录访问

    在本例中,要实现一个简单的登录验证过滤器,可以阻止未登录用户访问除了登录页面以外的其他后台管理页面。通过实现javax.servlet.Filter接口,我们创建了一个LoginFilter类。这个过滤器会在每个请求到达目标页面...

    servlet过滤器验证用户登录

    在IT领域,特别是Java Web开发中,Servlet过滤器(Filter)是实现用户权限管理、登录状态验证等关键功能的重要机制之一。本文将深入探讨如何利用Servlet过滤器来验证用户是否已登录,以及如何配置过滤器以针对特定的...

    过滤器(filter) 例子源码

    过滤器可以用于执行诸如数据校验、身份验证、字符编码转换、日志记录等多种任务,提高了代码的可复用性和模块化。 ### 二、过滤器的工作原理 过滤器的工作流程遵循以下步骤: 1. 用户发起HTTP请求。 2. 服务器...

    过滤器验证用户登录.rar

    在这个"过滤器验证用户登录"项目中,我们关注的是如何利用过滤器来实现用户身份的验证,确保只有已登录的用户才能访问特定的Web资源。这个项目结合了IntelliJ IDEA这一强大的Java开发工具,为开发者提供了高效且专业...

    PHP Filter过滤器全面解析

    在这个例子中,首先检查是否存在名为“email”的GET参数,然后使用`FILTER_VALIDATE_EMAIL`过滤器验证其是否为有效邮箱地址。 总的来说,PHP Filter过滤器是处理和验证输入数据的关键工具,确保数据安全性和应用的...

    filter过滤器的简单使用.rar

    在标题提到的"filter过滤器的简单使用.rar"压缩包中,很显然包含了一个关于如何在Maven项目和Spring Boot项目中使用Filter的示例。下面将详细介绍Filter的基本概念、工作原理以及如何在两种项目环境中应用。 **...

    java filter过滤器

    【Java Filter过滤器详解】 Java Filter是Java Servlet技术的一部分,它允许开发者在Servlet容器中对HTTP请求和响应进行拦截处理,实现数据过滤、权限控制、日志记录等多种功能。Filter的生命周期包括三个主要方法...

    Filter过滤器1

    Filter 有多种应用场景,例如禁用页面缓存、字符编码过滤器、身份验证过滤器等。禁用页面缓存的过滤器可以通过设置 response 的头信息来禁用缓存,例如设置 Expires、Cache-Control、Pragma 等头信息。 字符编码...

    Socket通信,封包处理, Filter过滤器处理

    Filter过滤器处理则是在数据传输或处理流程中添加的一层逻辑,用于拦截、修改或者增强数据。 首先,我们来深入理解Socket通信。Socket可以视为网络上的两个程序之间的一个连接点,通过这个连接点,数据可以在它们...

Global site tag (gtag.js) - Google Analytics