`
329087553
  • 浏览: 51585 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

过滤器

阅读更多
在项目开发中需要对string 类型的输入进行非法代码过滤于是有了 这段 字符串的过滤
public class StringFilter {

  /**
    * 过滤<, >,\n 字符的方法。
    * @param input 需要过滤的字符
    * @return 完成过滤以后的字符串
    */
  public static String filterHtml(String input) {

    input = input.replaceAll("&", "&");
    input = input.replaceAll("<", "<");
    input = input.replaceAll(">", ">");
    input = input.replaceAll(" ", " ");
    input = input.replaceAll("'", "'");
    input = input.replaceAll("\"", """);
    
    return input.replaceAll("\n", "<br>");
  }
}



或许对 struts 不够了解.  不知道其中有更好的方法
但是 对于风装好的 form 以及 pojo 层 对象的过滤, 上面 的还是无能为力
于是乎  有了下面对 对象的过滤, 
public class SuperFilter {
  private Object obj; // 传入的对象
  private List<String> Methodname = new ArrayList<String>(); // 方法名 与get 方法对象
  private Map<String, Mobj> map = new HashMap<String, Mobj>(); // key 为
  // 方法名列表的
  // 每个值 value
  // 为封装了与方法名对应的get
  // set
  // 方法的对象
  private List<Method> getList = new ArrayList<Method>(); // get 方法列表
  private List<Method> setList = new ArrayList<Method>();// set 方法列表

  public SuperFilter(Object obj, Class<?> cla) {
    this.obj = obj;
    String style = cla.getName();
    MethodSorter(obj, style);
    MethodFilter();
  }

  public SuperFilter(Object obj, String style) {
    this.obj = obj;
    MethodSorter(obj, style);
    MethodFilter();
  }

  private void MethodSorter(Object o, String name) {
    Method methods[] = null;
    try {
      methods = Class.forName(name).getDeclaredMethods();
    } catch (SecurityException e) {
      e.printStackTrace();
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
    }
    for (int i = 0; i < methods.length; i++) {
      Method m = methods[i];
      if (m.getName().startsWith("get")) {
        getList.add(m);
        String tempname = m.getName();
        Methodname.add(tempname.substring(3));
      }
      if (m.getName().startsWith("set")) {
        setList.add(m);
      }

    }

    for (int i = 0; i < Methodname.size(); i++) {
      String temp = Methodname.get(i);
      for (int m = 0; m < setList.size(); m++) {
        Method met = setList.get(m);
        if (met.getName().endsWith(temp)) {

          map.put(temp, new Mobj(getList.get(i), met));

        }
      }
    }

  }

  public void MethodFilter() {
    for (int i = 0; i < Methodname.size(); i++) {
      Mobj mobj = map.get(Methodname.get(i));
      Method methodget = mobj.getGetMethod();
      Method methodset = mobj.getSetMethod();

      try {
        if (String.class.isInstance(methodget.invoke(obj, null))) {

          String temp = (String) methodget.invoke(obj, null);
        //  System.out.println("~~~~~~~~~~~~~~~~~~");
          System.out.println(temp);
        //  System.out.println("~~~~~~~~~~~~~~~~~~");
          String tempAfterFilter = StringFilter.filterHtml(temp);
          methodset.invoke(obj, tempAfterFilter);

        }
      } catch (IllegalArgumentException e) {
        e.printStackTrace();
      } catch (IllegalAccessException e) {
        e.printStackTrace();
      } catch (InvocationTargetException e) {
        e.printStackTrace();
      }

    }

  }

  protected class Mobj {
    Method getMethod;
    Method setMethod;

    public Mobj(Method getMethod, Method setMethod) {
      this.getMethod = getMethod;
      this.setMethod = setMethod;
    }

    public Method getSetMethod() {
      return setMethod;
    }

    public void setSetMethod(Method setMethod) {
      this.setMethod = setMethod;
    }

    public Method getGetMethod() {
      return getMethod;
    }

    public void setGetMethod(Method getMethod) {
      this.getMethod = getMethod;
    }

  }

}

思路:
1 通过传入 对象  ,对象类型名,  获取出 对象自己的 getter and setter ,
并将其对应到 map 中
2 判断 其get 方法 的返回值类型 若是 string 类型 则调用 对应属性的getter  
3 将得到的 字符串 通过StringFilter 进行过滤后 ,调用对象的setter 将其保存到对象中  完成过滤
使用方法:
public ActionForward execute(ActionMapping mapping, ActionForm form,
      HttpServletRequest request, HttpServletResponse response) {
// 传入的form 表单 转换为对应类型   
    Login loginForm = (Login) form;

// 进行过滤
    new SuperFilter(loginForm,loginForm.getClass());
  ...................      return mapping.getInputForward();
    


  }
}
该过滤操作完全是针对风装好的对象  (例如 form bean)  进行字符过滤  可以通过对 stringFilter 的 相应配置 实现 特定字符的 转换任务

  (*^__^*)  一个过滤 就这样完成了.. 其中不足 还希望大家给予指正,感激不尽
分享到:
评论

相关推荐

    STM32的CAN过滤器详解.pdf

    每组过滤器可以是1个、2个或4个过滤器,这些过滤器并联工作,只要报文通过任意一个过滤器,就会被视为有效并进入相应的FIFO。 过滤器的工作模式主要有两种:标识符列表模式和标识符屏蔽位模式。在标识符列表模式下...

    过滤器图形符号(标准图形)

    ### 过滤器图形符号(标准图形) #### 知识点概述 在设计与工程技术领域,标准化图形符号的使用能够确保信息的有效传达与统一理解。《过滤器图形符号(标准图形)》一文介绍了几种常用的过滤器图形符号,这些符号...

    管道过滤器(软件体系结构)

    ### 管道过滤器(软件体系结构) #### 概述 随着软件系统规模和复杂性的不断增长,软件体系结构的设计变得尤为重要。良好的体系结构能够确保软件系统的成功部署与维护,而管道过滤器模式作为软件体系结构的一种...

    Servlet过滤器的简单使用源码+文档

    在标题"Servlet过滤器的简单使用源码+文档"中,我们可以理解为这个压缩包包含了一个关于Servlet过滤器的基础应用示例,以及相关的源代码和文档资料。描述中提到的"实现一个登陆界面",表明了过滤器可能被用作验证...

    多介质过滤器设计规范

    多介质过滤器设计规范主要涉及了工业水处理领域中一种重要的设备——多介质过滤器,其主要用于去除水中的悬浮物、胶体、微生物、有机物和油等杂质,以提升水质,确保供水满足使用需求。以下是对规范书中关键知识点的...

    servlet过滤器实例经典过滤器

    Servlet过滤器是Java Web开发中的一个重要组件,它允许开发者在请求到达Servlet之前或者响应离开Servlet之后进行拦截处理。本教程将深入讲解如何配置和使用Servlet过滤器,以及介绍五个经典的过滤器实例。 首先,让...

    JAVA过滤器标准代码

    ### JAVA过滤器标准代码解析与应用 在Java Web开发中,过滤器(Filter)是一种用于拦截请求和响应的重要机制,可以实现对用户请求的预处理和后处理,以及对响应的处理。本文将深入解析“JAVA过滤器标准代码”,探讨...

    管道过滤器程序,主要用java实现

    管道过滤器模式是一种设计模式,它在软件工程中被广泛应用于数据处理,特别是在Java编程语言中。这种模式通过连接一系列的处理组件(过滤器),每个组件执行特定的任务,来实现复杂的数据转换。在这个场景中,"管道...

    STM32 CAN过滤器滤波器配置详解

    STM32 CAN 过滤器滤波器配置详解 在嵌入式系统中,CAN(Controller Area Network)总线是常见的通信协议之一。STM32 微控制器也支持 CAN 通信协议。为了正确地实现 CAN 通信,需要了解 CAN 总线上的节点接收或发送...

    拦截器和过滤器的区别

    ### 拦截器与过滤器的区别 #### 一、概念简介 在现代软件开发过程中,特别是Web应用程序中,为了实现灵活高效的业务逻辑处理及控制流管理,常常会使用到两种设计模式:拦截器(Interceptor)与过滤器(Filter)。...

    Java过滤器,字符过滤,标签过滤

    首先,让我们了解一下Java过滤器的基础知识。在Java Servlet规范中,Filter接口定义了过滤器的行为。一个过滤器可以通过实现`doFilter()`方法来拦截请求和响应,并对其进行处理。通过在web.xml配置文件中定义过滤器...

    用户登陆过滤器

    在这个过滤器中,我们可以看到它主要由两部分组成:一部分是web.xml中的配置,另一部分是Java代码中的实现。 首先,在web.xml中,我们可以看到filter的配置,包括filter-name和filter-class两个参数。filter-name是...

    GridControl的过滤器的自定义

    "GridControl 的过滤器自定义查询" DevExpress 的 GridControl 提供了强大的过滤器功能,允许开发者自定义查询条件以满足复杂的数据检索需求。在本文中,我们将探讨如何自定义 GridControl 的过滤器以实现复杂的...

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

    使用servlet和jsp技术时,我们可以通过过滤器(Filter)来实现这样的安全防护机制。过滤器是一种服务器端的组件,它能够对请求和响应进行拦截,执行一些预处理或者后处理操作。它常用于进行登录验证、权限检查、字符...

    过滤器文档过滤器使用中的方法过滤器.pdf

    本文档将深入探讨过滤器的使用及其功能。 **过滤器概述** 过滤器(Filter)的主要作用是对客户端发起的HTTP请求进行预处理,也可以在响应返回给客户端之前进行后处理。例如,过滤器可以用于以下用途: 1. **敏感...

    过滤器(java编写的过滤器)

    在Java Web开发中,过滤器(Filter)是一种非常重要的技术组件,它可以在请求到达目标资源(如Servlet或JSP页面)之前或之后执行某些操作。过滤器可以用来实现各种功能,如用户认证、权限检查、编码转换、日志记录等。...

    vue 内置过滤器的使用总结(附加自定义过滤器)

    Vue不仅内置了一些过滤器,还允许开发者自定义过滤器以满足特定需求。 首先,我们来看看Vue内置过滤器的使用。 Vue内置过滤器非常丰富,包括但不限于: - `capitalize`:将字符串首字母大写。 - `uppercase`:将...

    jsp中的过滤器(含例子)

    这里,我们定义了一个名为`CharacterEncodingFilter`的过滤器,并将其映射到所有URL(`/*`),意味着任何请求都会经过这个过滤器。 3. 最后,部署应用并测试。现在,无论用户发送什么请求,服务器都会自动将字符...

    带过滤器的登录系统jsp+myeclipse+mysql

    标题中的“带过滤器的登录系统jsp+myeclipse+mysql”表明这是一个使用Java服务器页面(JSP)、MyEclipse集成开发环境以及MySQL数据库构建的登录系统,其中整合了过滤器(Filter)技术。这样的系统通常用于实现用户...

    WAS 6.0.2.9 部署应用使用过滤器问题解决办法

    在WAS 6.0.2.9中,可能遇到的问题可能涉及到过滤器配置、过滤器链执行顺序、过滤器异常处理或过滤器与应用程序其他组件的交互等。 首先,让我们了解过滤器的基本概念。在web.xml配置文件中,我们定义过滤器,包括...

Global site tag (gtag.js) - Google Analytics