带有时区和 SimpleDateFormat 的无法解析的日期

Unparseable date with timezone and SimpleDateFormat

我正在尝试构建一个查询,以便能够按日期在字段中进行搜索。我正在尝试在下面的代码中显示,但出现此错误:

Class

java.text.ParseException

留言 无法解析的日期:

"sun.util.calendar.ZoneInfo[id="BST",offset=21600000,dstSavings=0,useDaylight=false,transitions=8,lastRule=null]"

提前致谢

if (params.dateFromQuery){
                TimeZone timez = user.timeZone
                SimpleDateFormat sdfIn = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                SimpleDateFormat sdfOut = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
                String input = timez;
                Date date = sdfIn.parse(input);

                ge('startTime', sdfOut.format(date))
                params.dateFrom = sdfOut.format(date)
            }

您根本不解析日期 - 您解析时区的字符串表示形式:

TimeZone timez = user.timeZone 
String input = timez; //THIS IS WRONG
Date date = sdfIn.parse(input);

检查您从何处检索输入 - 必须在您的查询中。

它应该是这样的:

TimeZone timez = user.timeZone 
sdfIn.setTimeZone(timez);
String input = params.dateFromQuery; //from your webform
Date date = sdfIn.parse(input);

如果您希望在 parsing/formatting 中使用时区,您需要设置

sdfIn.setTimeZone(timez);

在使用该实例解析/格式化日期之前。

//Formatting time to set as 'startTime'. Which timezone to set here?
ge('startTime', sdfOut.format(date))

//Writing to input parameter?!
params.dateFrom = sdfOut.format(date)