基于表单数据的封装,泛型,反射以及使用BeanUtils进行处理

简介: 在Java Web开发过程中,会遇到很多的表单数据的提交和对表单数据的处理。而每次都需要对这些数据的字段进行一个一个的处理就显得尤为繁琐,在Java语言中,面向对象的存在目的便是为了消除重复代码,减少我们程序员的负担。

在Java Web开发过程中,会遇到很多的表单数据的提交和对表单数据的处理。而每次都需要对这些数据的字段进行一个一个的处理就显得尤为繁琐,在Java语言中,面向对象的存在目的便是为了消除重复代码,减少我们程序员的负担。因此,在这里和大家分享一下我学到的一个小技巧。


对于封装


这里说的“封装”,是指将从客户端提交的表单数据封装到一个bean层entitry中。这样可以方便对数据的处理。下面就来看一个具体的bean实例化的小例子吧。
比如说我们从网页上获得用户的登录信息,一般来说是用户名和密码信息,因此我们就可以将这两个数据封装到一个bean中。
下面是一个class类:

package beanenclosetest;

public class PersonBean {

    private String name;
    private String password;

    @Override
    public String toString() {
        return "PersonBean [name=" + name + ", password=" + password + "]";
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }


}

这样就可以将数据封装起来了。

泛型处理


这里说的泛型是对于beanUtil层面的数据加工。这样就可以使得其他人在调用该方法时不必再进行强制的类型转换,这样在一定的程度上加强了程序的安全性。比如下面这个代码,就用到了泛型的操作。

package beanenclosetest;

import java.lang.reflect.InvocationTargetException;
import java.util.Enumeration;

import javax.servlet.http.HttpServletRequest;

import org.apache.commons.beanutils.BeanUtils;

public class PersonBeanUtils {


    public static <T> T request2Bean(HttpServletRequest request, Class<T> t ){

        try {
            T bean = t.newInstance();

            Enumeration<String> e = request.getParameterNames();
            while(e.hasMoreElements()){
                String name = (String) e.nextElement();
                String value = request.getParameter(name);
                BeanUtils.setProperty(bean, name, value);
            }

            return bean;


        } catch (Exception e) {
            // TODO Auto-generated catch block
            throw new RuntimeException(e);
        }
    }

}

反射


public static T request2Bean(HttpServletRequest request, Class t ){

    try {
        T bean = t.newInstance();
    }catch(Exception e){
    //do something 
    }

这里面就是用到了反射的操作。通过参数获得一个bean的字节码信息,这里面其实就是一个类的内部的所有信息的实体。

使用BeanUtils


BeanUtils是一个apache开源的一个项目,旨在帮助程序员减轻对字段数据的加工负担。其使用方法非常简单,但是需要注意的是需要commons-logging 包的支持。否则会报出程序的异常错误信息。
如下:

public static <T> T request2Bean(HttpServletRequest request, Class<T> t ){

        try {
            T bean = t.newInstance();

            Enumeration<String> e = request.getParameterNames();
            while(e.hasMoreElements()){
                String name = (String) e.nextElement();
                String value = request.getParameter(name);
                BeanUtils.setProperty(bean, name, value);
            }

            return bean;


        } catch (Exception e) {
            // TODO Auto-generated catch block
            throw new RuntimeException(e);
        }
    }

这里面的BeanUtils.setProperty(bean,name,value);就是处理方式。是不是很简单啊,通过者一行代码就可以将bean字段的属性信息添加到bean中并返回。

至此,本篇博客的讲解就结束了。下面一起来看一看一个实用的案例吧。


具体的小案例


打开chrome浏览器,输入tomcat服务器上的对应的网址,然后为了更加真实的模仿实际项目中的情景,我们就直接在URL地址上添加parameter吧,如下:
这里写图片描述

然后打开服务器终端terminal,然后就可以看到如下信息:
这里写图片描述

由此,我们的这个“基于表单数据的封装,泛型化,反射操作,就完成了。


总结:

  • 使用BeanUtils进行操作的时候需要注意对包的处理。
  • 反射操作的时候需要注意字节码的转换方式。
  • 在静态方法中使用泛型需要进行声明。
  • 注意代码逻辑的灵活使用!
目录
相关文章
|
6月前
|
JSON Java API
GSON 泛型对象反序列化解决方案
GSON 泛型对象反序列化解决方案
274 0
|
C# 开发者
C#扩展方法和工具类的区别
扩展方法和工具类的主要区别在于它们的作用。扩展方法旨在扩展现有的类,而工具类旨在提供一组通用且可靠的方法来执行某些任务。当需要扩展现有的类时,使用扩展方法;当需要实用函数来执行通用任务时,使用工具类。
73 0
|
11月前
|
Java
反射获取声明泛型工具类
反射获取声明泛型工具类
55 0
|
安全 索引
常用泛型数据接口类——List
常用泛型数据接口类——List
148 0
C#反射与特性(四 实例化类型
C#反射与特性(四 实例化类型
280 0
C#反射与特性(四 实例化类型
|
Java
Cglib应用:基于Map动态生成JavaBean对象
再某些特殊的场景下,存在手动创建java类的case,比如我有个需求,希望根据简单的Map对象,来生成一个对应的Java bean,可以怎么整? 针对这个而典型的场景,先考虑是否有现成可用的开源工具类来实现,比如我们经常接触到cglib,它可以动态生成代理对象,那么生成Java Bean也没有什么问题 接下来我们看一下使用cglib来创建bean的方式
788 0
|
监控 Java API
字节码编程,Byte-buddy篇三《使用委托实现抽象类方法并注入自定义注解信息》
截至到本章节关于字节码框架 Byte-buddy 的大部分常用 API 的使用已经通过案例介绍比较全面了,接下来介绍关于如何去实现一个抽象类以及创建出相应注解(包括类的注解和方法的注解)的知识点。而注解的这部分内容在一些监控或者拦截处理的场景下还是比较常用的,所以在这章节我们会通过一个例子来创建出含有自定义注解的类和方法。 如果你已经阅读了之前的系列文章,这部分学习的内容并不会有太多的陌生,主要是关于委托(MethodDelegation)方法的使用以及补充自定义注解。
413 0