Java * 和过滤器的区别分析

作者:GTQ28 时间:2021-11-06 22:28:46 

一、过滤器(filter)

过滤器处于客户端与Web资源(Servlet、JSP、HTML)之间,客户端与Web资源之间的请求和响应都要通过过滤器进行过滤。举例:在过滤器中定义了禁止访问192.10.10.1这个地址,那么当客户端发出访问192.10.10.1的请求时,经过过滤器后,客户端得到的响应是出现该IP禁止访问的提示。在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts的 action进行业务逻辑,比如过滤掉非法url(不是login.do的地址请求,如果用户没有登陆都过滤掉),或者在传入servlet或者 struts的action前统一设置字符集,或者去除掉一些非法字符

二、 * (interceptor)

* 是一种面向方面/切面编程(AOP Aspect-Oriented Programming),而面向切面就是将多个模块的通用服务进行分离,如权限管理、日志服务,他们在多个模块中都会用到,就可以将其各自封装为一个可重用模块。而这些通用服务的具体实现是通过 * 来完成,比如用户客户端访问一些保密模块都应先通过权限审查的 * 来进行权限审查,确定用户是否具有该项操作的权限后方能向下执行。在面向切面编程的就是在你的service或者一个方法前调用一个方法,或者在方法后调用一个方法,比如 * 就是 * 的简单实现,在你调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作。

三、 * 与过滤器的区别

1、 * 是基于java的反射机制的,而过滤器是基于函数回调(职责链)

2、过滤器依赖与servlet容器,而 * 不依赖与servlet容器

3、 * 只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用

4、 * 可以访问action上下文、值栈里的对象,而过滤器不能

5、在action的生命周期中, * 可以多次被调用,而过滤器只能在容器初始化时被调用一次

执行顺序 :过滤前 - 拦截前 - Action处理 - 拦截后 - 过滤后。个人认为过滤是一个横向的过程,首先把客户端提交的内容进行过滤(例如未登录用户不能访问内部页面的处理);过滤通过后, * 将检查用户提交数据的验证,做一些前期的数据处理,接着把处理后的数据发给对应的Action;Action处理完成返回后, * 还可以做其他过程(还没想到要做啥),再向上返回到过滤器的后续操作。

±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±±

四、详细说明

* :是在面向切面编程的就是在你的service或者一个方法前调用一个方法,或者在方法后调用一个方法比如 * 就是 * 的简单实现,在你调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作。

下面通过实例来看一下过滤器和 * 的区别:
使用 * 进行/admin 目录下jsp页面的过滤


<package name="newsDemo" extends="struts-default" namespace="/admin">
       <interceptors>
           <interceptor name="auth" class="com.test.news.util.AccessInterceptor" />
           <interceptor-stack name="authStack">
               <interceptor-ref name="auth" />
           </interceptor-stack>
       </interceptors>
       <!-- action -->
       <action name="newsAdminView!*" class="newsAction" method="{1}">
           <interceptor-ref name="defaultStack"/>
           <interceptor-ref name="authStack">
           </interceptor-ref>

下面是我实现的Interceptor class:


package com.test.news.util;
import java.util.Map;
import com.opensymphony.xwork2.ActionContext;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.test.news.action.AdminLoginAction;
/**
* @author chaoyin
*/
public class AccessInterceptor extends AbstractInterceptor {
   private static final long serialVersionUID = -4291195782860785705L;

@Override
   public String intercept(ActionInvocation actionInvocation) throws Exception {

ActionContext actionContext = actionInvocation.getInvocationContext();
        Map session = actionContext.getSession();

//except login action
        Object action = actionInvocation.getAction();
       if (action instanceof AdminLoginAction) {
           return actionInvocation.invoke();
        }
       //check session
       if(session.get("user")==null ){
           return "logout";
        }
       return actionInvocation.invoke();//go on
    }
}

过滤器:是在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts的 action进行业务逻辑,比如过滤掉非法url(不是login.do的地址请求,如果用户没有登陆都过滤掉),或者在传入servlet或者 struts的action前统一设置字符集,或者去除掉一些非法字符.

使用过滤器进行/admin 目录下jsp页面的过滤,首先在web.xml进行过滤器配置:


<filter>
       <filter-name>access filter</filter-name>
       <filter-class>
            com.test.news.util.AccessFilter
       </filter-class>
   </filter>
   <filter-mapping>
       <filter-name>access filter</filter-name>
       <url-pattern>/admin/*</url-pattern>
   </filter-mapping>

下面是过滤的实现类:


package com.test.news.util;
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.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class AccessFilter implements Filter {
/**
* @author chaoyin
*/

public void destroy() {

}
   public void doFilter(ServletRequest arg0, ServletResponse arg1,
            FilterChain filterChain) throws IOException, ServletException {

HttpServletRequest request = (HttpServletRequest)arg0;

HttpServletResponse response = (HttpServletResponse)arg1;

HttpSession session = request.getSession();

if(session.getAttribute("user")== null && request.getRequestURI().indexOf("login.jsp") ==-1 ){
            response.sendRedirect("login.jsp");
           return ;
        }

filterChain.doFilter(arg0, arg1);
    }
   public void init(FilterConfig arg0) throws ServletException {

}
}

来源:https://blog.csdn.net/zhangzhanbin/article/details/117161231

标签:Java, , ,过滤器
0
投稿

猜你喜欢

  • Android编程实现google消息通知功能示例

    2023-02-02 20:00:27
  • Java实现添加条形码到PDF表格的方法详解

    2023-04-26 12:37:25
  • Android7.0行为变更之适配File Provider的方法

    2021-09-24 08:02:38
  • Kotlin基础学习之循环和异常

    2023-05-26 00:42:12
  • Android实现连连看游戏

    2021-08-22 09:51:17
  • Android实战教程第一篇之最简单的计算器

    2023-03-12 17:57:54
  • 基于SpringBoot生成二维码的几种实现方式

    2022-02-27 16:24:31
  • 解决C#中Linq GroupBy 和OrderBy失效的方法

    2022-11-21 00:25:11
  • 如何利用反射生成 MyBatisPlus中QueryWrapper动态条件

    2021-10-20 14:59:40
  • java io文件操作删除文件或文件夹的7种方法

    2022-08-09 13:29:21
  • MybatisX-Generator自动代码生成插件教程

    2022-01-08 10:50:48
  • IDEA快速搭建spring boot项目教程(Spring initializr)

    2023-08-17 21:11:16
  • 配置Ant执行Jmeter脚本过程详解

    2023-11-09 22:35:29
  • Java @Value("${xxx}")取properties时中文乱码的解决

    2023-08-14 06:25:50
  • 线程局部变量的实现 ThreadLocal使用及场景介绍

    2023-11-10 03:19:26
  • JNI语言基本知识

    2022-01-20 20:02:46
  • Android自定义view实现滚动选择控件详解

    2022-12-05 09:54:06
  • Android TextView自定义数字滚动动画

    2023-10-03 09:48:17
  • Unity实现轮盘方式的按钮滚动效果

    2022-06-19 16:53:57
  • java实现上传网络图片到微信临时素材

    2022-09-21 08:43:23
  • asp之家 软件编程 m.aspxhome.com