[技巧篇]17.那些年一直再逃避的问题,还债Web阶段!

  四海行唐的一阶段和二阶段的时候,再使用数据的时候总是使用List<Map<String,Object>>的东西,但是胖先生一直不怎么喜欢!

  所以我再凌云17的Web阶段的时候,使用了从前端表单提交数据,直接再Servlet变成对象,后台从数据库查询的数据也直接编程对象,例如List<User> 形式

  我们没有自己去写ORM框架,而是再现有的开源的基础上来搞定,因为再Web阶段说ORM是一种比较扯的,风险比较大!


  一开始的时候,我们使用先使用实例化号对象,再通过 request.getParameter("表单的name对应的值"); 每个属性进行setter操作,并且还需要判断,重复的操作实在是浪费我们的学习生命。

  所以我使用了Apache提供的开源的工具BeanUtils,让我解决了这个问题


  从前台传递数据的  form 表单中name属性对应的值 实体Bean中的值 以及数据的字段,三者保持一致,这是我们的约定!

  并且使用了大家不太使用的 request.getParameterMap() ,搞定!

  形式如下 : 

/**
胖先生的核心代码
**/
//获取客户端的数据
Map<String, String[]> map = request.getParameterMap();
//对象实例化
TestData testData = new TestData();
//数据转换
BeanUtils.populate(testData, map);

  当时有一些同学再这里遇到了问题,这里我们不考虑大数据类型!但是日期这类型就没有办法转换为java.util.Date类型,当时我让我的学生再实体Bean中改成了String类型,解决了这个问题,其实是偷懒的方式,当时没有过多的去研究,所以抱歉了!

  由于BeanUtils中中没有对日期类型的处理,我自己写了一个转换日期处理的类,模仿写的BeanUtils中的转换器写的

package com.p5hui.utils;

import java.text.ParseException;

import org.apache.commons.beanutils.Converter;
import org.apache.commons.lang3.time.DateUtils;

public class DateConvert implements Converter {
    private String[] parsePatterns = {
        "yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", "yyyy-MM", 
        "yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", "yyyy/MM",
        "yyyy.MM.dd", "yyyy.MM.dd HH:mm:ss", "yyyy.MM.dd HH:mm", "yyyy.MM"};

    @SuppressWarnings("unchecked")
    @Override
    public <T> T convert(Class<T> arg0, Object arg1) {
         String p = (String)arg1;
            if(p== null || p.trim().length()==0){
                return null;
            }   
            try{
                return (T) DateUtils.parseDate(p, parsePatterns);
            }
            catch(Exception e){
                try {
                    return (T) DateUtils.parseDate(p, parsePatterns);
                } catch (ParseException ex) {
                    return null;
                }
            }
            
        }
    }

  在这里我使用了import org.apache.commons.lang3.time.DateUtils;对日期格式化,但是这个时候就有一个问题,如果让转换器好使呢?百度了一下资料,可以继承BeanUtils之后,进行注册操作

package com.p5hui.utils;

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

import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.beanutils.ConvertUtils;

public class BeanUtilEx extends BeanUtils {

    private BeanUtilEx() {
    }

    static {
        // 注册sql.date的转换器,即允许BeanUtils.copyProperties时的源目标的sql类型的值允许为空
        // ConvertUtils.register(new SqlDateConverter(), java.util.Date.class);
        // ConvertUtils.register(new SqlTimestampConverter(),
        // java.sql.Timestamp.class);
        // 注册util.date的转换器,即允许BeanUtils.copyProperties时的源目标的util类型的值允许为空
        // ConvertUtils.register(new UtilDateConverter(), java.util.Date.class);

        ConvertUtils.register(new DateConvert(), java.util.Date.class);
    }

    public static void populate(Object target, Map source)
            throws InvocationTargetException, IllegalAccessException {
        
        org.apache.commons.beanutils.BeanUtils.populate(target, source);
    }
}

如何再Servlet当中使用呢?核心代码如下:

public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        request.setCharacterEncoding("UTF-8");
        //request.getParameter("表单的name对应的值");
        
        Map<String, String[]> map = request.getParameterMap();
        
        TestData testData = new TestData();
        
        try {
            BeanUtilEx.populate(testData, map);
            //BeanUtilsBean.getInstance().populate(arg0, arg1);
            //BeanUtilsBean2.getInstance().populate(arg0, arg1);
            System.out.println(testData);
        } catch (IllegalAccessException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        response.setContentType("text/html;charset=UTF-8");
   
    }

jsp页面代码如下

  <form action="test01.shxt" method="post">
        整型:<input type="text" name="age"> <br/>  
        字符串:<input type="text" name="name"/><br/>   
        日期:<input type="text" name="create_date"> <br/>    
          金额:<input type="text" name="salary"> <br/>    
            长度:<input type="text" name="length"> <br/>   
            爱好:<input type="checkbox" name="hobbys"value="1"> <br/>    
            <input type="checkbox" name="hobbys" value="football"> <br/>     
        <button type="submit">提交</button>
    </form>

TestData.java的实体Bean如下

package com.p5hui.model;

import java.util.Arrays;
import java.util.Date;

public class TestData {
    
    private Integer age;
    private String account;
    private Date create_date;
    private Float salary;
    private Long length; 
    private String[] hobbys; 
    public String[] getHobbys() {
        return hobbys;
    }
    public void setHobbys(String[] hobbys) {
        this.hobbys = hobbys;
    }
    public Long getLength() {
        return length;
    }
    public void setLength(Long length) {
        this.length = length;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    public String getAccount() {
        return account;
    }
    public void setAccount(String account) {
        this.account = account;
    }
    public Date getCreate_date() {
        return create_date;
    }
    public void setCreate_date(Date create_date) {
        this.create_date = create_date;
    }
    public Float getSalary() {
        return salary;
    }
    public void setSalary(Float salary) {
        this.salary = salary;
    }
    @Override
    public String toString() {
        return "TestData [age=" + age + ", account=" + account
                + ", create_date=" + create_date + ", salary=" + salary
                + ", length=" + length + ", hobbys=" + Arrays.toString(hobbys)
                + "]";
    }

}

这个过程我还测试一下如何使用SQLite这里就不说了,这个不是重点

 胖先生 原创出品,必是精品!  

 

posted on 2015-09-26 16:20  胖先生  阅读(1301)  评论(0编辑  收藏  举报