时间异常集(Eclipse+SSM+Bootstrap+Bootstrap Table)【需修整】

28 篇文章 0 订阅
25 篇文章 0 订阅

(1) 

java.text.ParseException: Format.parseObject(String) failed
	at java.text.Format.parseObject(Unknown Source)
	at com.ht.qyf.controller.DutyPlanController.add(DutyPlanController.java:70)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
	at java.lang.reflect.Method.invoke(Unknown Source)
	at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:221)
	at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:137)
	at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110)
	at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:777)
	at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:706)
	at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:943)
	at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:877)
	at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:966)
	at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:868)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:646)
	at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:842)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:727)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
	at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
	at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
	at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
	at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:501)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
	at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408)
	at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1040)
	at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:607)
	at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:313)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
	at java.lang.Thread.run(Unknown Source)

parseObject(String参数)   返回Date类型,而我的startTime是Date类型,Date要转Date,我在dp.getStartTime()前加上‘ “”+ ’,这是简单粗暴的变成String类型的方法,可是不管用,所以报了上面的错误!!!

dp这个Javabean对象的属性startTime结果是从页面传来的,因为Spring-web配置文件:

且页面传的值里有时间类型,则必经DateUtil类,

所以返回的startTime或endTime的值是Date(convert方法是Date类型的嘛!),但是打印结果是“Thu Jan 01 04:05:00 CST 1970”【我只想要“时和分”,而且不是这种格式】,所以试了上面的(加‘ “”+ ’)方法,你也看到了,报了这样的错误了!!!

------------------------------打印结果---------------------------------------
--->>进入控制器前时间:1551667360303
source=03:45
source=04:05
-----------add------DutyPlanVo [planId=0, weekArrangeName=是, required=333333, week=是, empId=0, 
startTime=Thu Jan 01 04:05:00 CST 1970, endTime=Thu Jan 01 03:45:00 CST 1970, remark=无]

 

 接着,我索性,不转格式了,就让他这样,先看看数据库数据能不能新增进去,没想到,时间记录不是“Thu Jan 01 04:05:00 CST 1970”,而且正是我想要的呀(DataUtil类里的方法把时间从页面得到的转成数据库能读的?!Date类型,所以不用管):

(2)

spring-web.xml:(页面发送至后台,都有先经过配置,而且配置里有时间拦截)

public class DateUtil  implements Converter<String, Date> {

    @Override
    public Date convert(String source) {
    	
    	System.out.println("source="+source);
        //实现将字符串转成日期类型(格式是yyyy-MM-dd HH:mm:ss)
        SimpleDateFormat dateFormat = null;
        if(!StringUtils.isEmpty(source)){
        	//判断日期字符串是否包含了时间部分
        	int pos1 = source.indexOf(":");//从左往右查找字符串中第一个冒号的位置
        	int pos2 = source.lastIndexOf(":");//从右往左查找字符串中第一个冒号的位置
        	source = source.replace("T", " ");//把字符串中的T替换为空格
            if(pos1>0 && pos1 != pos2){
                dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            }else if(pos1>0 && pos1==pos2){
            	source = source +":00";
            	dateFormat=new SimpleDateFormat("HH:mm:ss");
//            	dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            }else{
                dateFormat = new SimpleDateFormat("yyyy-MM-dd");
            }
        }
        try {
            return dateFormat.parse(source);
        } catch (Exception e) {
            e.printStackTrace();
        }
        //如果参数绑定失败返回null
        return null;
    }
}

配置好了,进入Controller前,先进拦截器和DataUtil类,新增中有“时间”,(直接说经过DataUtil的)去DataUtil类,再次设置时间,因为我的时间是“时:分”,所以遇到了困难,我Debug看了下,经常在DataUtil的return两个时间之后,没有进入add()方法里面,导致断点没有用上,而且页面弹出:“出现错误”弹框,即:死在了add门口!!!

还有,

一:页面列表的时间字段对应记录没有转格式,成了“长整型”的一串数字,

二:修改时,值都会赋值到对应框里,唯有时间框里没有值(debug时,发现值【包括时间值】都传到了页面)

解决方案都是这个:

1、

2、 

总之,要有这个注解 :

@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss或HH:mm或yyyy-MM-dd",timezone="GMT+8")

二:改了之后:

  (3)

我弄查询条件在页面上,我弄了“时间下拉框”,在XxxDAO配置文件里这么取

数据库里查询没有时间格式问题:

但XxxDAO配置文件取了后,给Controller取值并传给dutyPlanList页面(index方法,是“点击menu”之后立马进入,获取了某下拉框的值后,立即去对应页面,页面列表的值,ajax与json配合使用来获取),显示页面的“时间下拉框”,值都是:“Thu Jan 01 04:05:00 CST 1970”这种的!!!

请同学帮忙,解决:

<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>

 

后来,页面显示的“时间下拉框”的值都是:“19点30分”这种的 

参考:JSP中利用JSTL标签对日期格式化

(4)

input[type='date‘]调起时间产生问题总结

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Yvette_QIU

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值