SpringMVC表单或Json中日期字符串与JavaBean的Date类型的转换

场景一:表单中的日期字符串和JavaBean的Date类型的转换

在使用SpringMVC的时候,经常会遇到表单中的日期字符串和JavaBean的Date类型的转换, 例如,如下代码S_ROLE_QO这个bean中包含有Date类型属性,不处理就拿不到值。

/**

* 分页取角色列表

* @param s_ROLE_QO 角色查询条件

* @return

*/

@RequestMapping(value = "/loadRoles", method = RequestMethod.GET)

@ResponseBody

public ServerResponse<List<S_ROLE_EO>> loadRoles( S_ROLE_QO s_ROLE_QO) {

PageHelper.startPage(s_ROLE_QO.getPageIndex(), s_ROLE_QO.getPageSize());

List<S_ROLE_EO> lst = s_ROLE_DAO.getRolesByConditionWithPaging(s_ROLE_QO);

PageInfo<S_ROLE_EO> page = new PageInfo<S_ROLE_EO>(lst);

return new ServerResponse<List<S_ROLE_EO>>(1, null, lst, page.getTotal());

}

而SpringMVC默认不支持这个格式的转换,所以需要手动配置,自定义数据的绑定才能解决这个问题。

WebDataBinder是用来绑定请求参数到指定的属性编辑器.由于前台传到controller里的值是String类型的,当往Model里Set这个值的时候,如果set的这个属性是个对象,Spring就会去找到对应的editor进行转换,然后再SET进去。

代码如下:

public static String GREGORIAN_DATEFORMAT= "EEE MMM dd yyyy hh:mm:ss z";

//将表单中特定日期类型的日期字符串转换成Javabean中的日期类型的属性

@InitBinder

protected void initBinder(WebDataBinder binder) {

SimpleDateFormat dateFormat = new SimpleDateFormat(GREGORIAN_DATEFORMAT, Locale.ENGLISH);

binder.registerCustomEditor(Date.class, new CustomDateEditor(dateFormat, true));

}

场景二:Json中的日期字符串和JavaBean的Date类型的转换

还是上面的代码,只不过加了个@RequestBody,采用json格式传参

这个时候处理方式:

往工程中引入以下包,如果是maven工程,在pom文件中加入

<dependency>

<groupId>com.fasterxml.jackson.core</groupId>

<artifactId>jackson-core</artifactId>

<version>2.7.3</version>

</dependency>

<dependency>

<groupId>com.fasterxml.jackson.core</groupId>

<artifactId>jackson-annotations</artifactId>

<version>2.7.3</version>

</dependency>

<dependency>

<groupId>com.fasterxml.jackson.core</groupId>

<artifactId>jackson-databind</artifactId>

<version>2.7.3</version>

</dependency>

然后在工具包添加如下工具类:

@Component

public class JsonDateSerializer extends JsonSerializer<Date> {

@Override

public void serialize(Date date, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonProcessingException {

jsonGenerator.writeString(DateUtil.format(date));

}

}

public class JsonDateDeSerializer extends JsonDeserializer<Date> {

@Override

public Date deserialize(JsonParser p, DeserializationContext ctxt)

throws IOException, JsonProcessingException {

String dataFormat=null;

String date = p.getText();

// 判断客户端传过来的是否是UTC类型

if (p.getText().contains("Z")) {

dataFormat="yyyy-MM-dd'T'HH:mm:ss.SSS Z";

date=date.replace("Z", " UTC");

}

return    DateUtil.format(date,dataFormat) ;

}

}

/**

* 日期工具类

*

* Date类型转换为日期字符串之间的转换

*

*/

public class DateUtil {

/**

* 将Date类型转换为字符串

*

* @param date

* 日期类型

* @return日期字符串

*/

public static String format(Date date) {

return format(date, "yyyy-MM-dd HH:mm:ss");

}

/**

* 将Date类型转换为字符串

*

* @param date

* 日期类型

* @param pattern

* 字符串格式

* @return日期字符串

*/

public static String format(Date date, String pattern) {

if (date == null) {

return "null";

}

if (pattern == null || pattern.equals("") || pattern.equals("null")) {

pattern = "yyyy-MM-dd HH:mm:ss";

}

return new java.text.SimpleDateFormat(pattern).format(date);

}

/**

* 将字符串转换为Date类型

*

* @param date

* 字符串类型

* @return日期类型

*/

public static Date format(String date) {

return format(date, null);

}

/**

* 将字符串转换为Date类型

*

* @param date

* 字符串类型

* @param pattern

* 格式

* @return日期类型

*/

public static Date format(String date, String pattern) {

if (pattern == null || pattern.equals("") || pattern.equals("null")) {

pattern = "yyyy-MM-dd HH:mm:ss";

}

if (date == null || date.equals("") || date.equals("null")) {

return new Date();

}

Date d = null;

try {

SimpleDateFormat sdf = new SimpleDateFormat(pattern);

if (pattern.equals("yyyy-MM-dd'T'HH:mm:ss.SSS Z")) {

sdf.setTimeZone(TimeZone.getTimeZone("GMT"));

}

d = sdf.parse(date);

} catch (ParseException pe) {

}

return d;

}

}

最后在JavaBean的Date类型属性的get set方法上添加如下注解,注意springMVC的注解驱动<mvc:annotation-driven> 要配置

@JsonSerialize(using = JsonDateSerializer.class)

public Date getCreateTimeStart() {

return createTimeStart;

}

@JsonDeserialize(using = JsonDateDeSerializer.class)

public void setCreateTimeStart(Date createTimeStart) {

this.createTimeStart = createTimeStart;

}

SpringMVC表单或Json中日期字符串与JavaBean的Date类型的转换的更多相关文章

  1. 日期字符串转为java.sql.Date

    日期字符串转为java.sql.Date类型 问题引出:在将一个日期字符串通过sql语句,插入到数据表的日期字段(字段类型是DATE),时遇到一个问题,如何将一个日期字符串转成java.sql.Dat ...

  2. 表单中的日期 字符串和Javabean中的日期类型的属性自动转换

    搞了一上午的bug最终还是因为自己springMVC的注解不熟悉的原因,特记录. 在实际操作中经常会碰到表单中的日期 字符串和Javabean中的日期类型的属性自动转换, 而springMVC默认不支 ...

  3. 表单序列化json字符串和js时间格式化

    js时间格式化 new Date().format("时间格式") Date.prototype.format = function(fmt) { var o = {        ...

  4. SpringMVC 表单验证

    SpringMVC 表单验证 本章节内容很丰富,主要有基本的表单操作,数据的格式化,数据的校验,以及提示信息的国际化等实用技能. 首先看效果图 项目结构图 接下来用代码重点学习SpringMVC的表单 ...

  5. ★★★【卡法 常用js库】: js汇合 表单验证 cookie设置 日期格式 电话手机号码 email 整数 小数 金额 检查参数长度

    [卡法 常用js库]: js汇合 表单验证  cookie设置  日期格式  电话手机号码  email  整数  小数  金额   检查参数长度 // +---------------------- ...

  6. js Form表单转json格式,及后台接收(多种方法)

    转载:https://blog.csdn.net/qq_40138785/article/details/81533015 一.serialize()方法格式:var data = $("# ...

  7. (转载)SPRINGMVC表单标签简介

    SpringMVC表单标签简介 在使用SpringMVC的时候我们可以使用Spring封装的一系列表单标签,这些标签都可以访问到ModelMap中的内容.下面将对这些标签一一介绍. 在正式介绍Spri ...

  8. SpringMVC表单标签简介

    在使用SpringMVC的时候我们可以使用Spring封装的一系列表单标签,这些标签都可以访问到ModelMap中的内容.下面将对这些标签一一介绍. 在正式介绍SpringMVC的表单标签之前,我们需 ...

  9. 将forme表单转换为Json对象

    //将Form 表单转换为Json字符串 $.fn.serializeObject = function () { var o = {}; var a = this.serializeArray(); ...

随机推荐

  1. java并发学习--第一章 线程的创建

    所谓的并发就是指一个时间段中有几个程序都处于已启动运行到运行完毕之间,且这几个程序都是在同一个处理机上运行,但任一个时刻点上只有一个程序在处理机上运行.所以我们看似几个线程在同时进行,其实在操作系统中 ...

  2. 转发一个robotframework的循环

    Click_Element Xpath=//b[text()='系统投放管理'] Sleep 1 Click_Element Xpath=//span[text()='全部投放情况查询'] Sleep ...

  3. C# 获取路径中,文件名、目录、扩展名等

    string path = "C:\\dir1\\dir2\\foo.txt"; string str = "GetFullPath:" + Path.GetF ...

  4. 170817关于AJAX的知识点

    1.AJAX                  [1] AJAX简介                        全称: Asynchronous JavaScript And XML        ...

  5. js数组声明+split()方法

    split()方法:var words = sentence.split(' '): "hello".split("", 3) //可返回 ["h&q ...

  6. MySQL5.6同步指定数据库

    需求:生产环境同步sakila (root@localhost) [(none)]> show databases;+--------------------+| Database |+---- ...

  7. POJ 1066 Treasure Hunt [想法题]

    题目链接: http://poj.org/problem?id=1066 --------------------------------------------------------------- ...

  8. r_action

    皮尔逊相关系数 斯皮尔曼等级相关(Spearman Rank Correlation) http://wiki.mbalib.com/wiki/斯皮尔曼等级相关 从表中的数字可以看出,工人的考试成绩愈 ...

  9. 术语-PM:PM/项目管理 百科

    ylbtech-术语-PM:PM/项目管理 百科 PM项目管理(Project Management),是以项目为对象的系统管理方法,通过一个临时性的.专门的柔性组织,对项目进行高效率的计划.组织.指 ...

  10. mysql.connector.errors.ProgrammingError: 1698 (28000): Access denied for user 'root'@'localhost'

    排错,首先在sql编辑工具 通过测试连接,查看一下自己的密码是否正确 : 由此可见,是自己的密码错误,输入正确的密码后 在这里把密码修改为正确之后程序运行正常 #初始化数据库连接 engine = c ...