为什么我无法将已经存在的 RFC3339 字符串解析回 RFC3339 字符串?

How come I cannot parse an already RFC3339 string back to a RFC3339 string?

我正在将字段类型为 VARCHAR(255) 的变量存储到 MySQL 数据库中,如下所示:

ts, err := time.Parse(time.RFC3339, nonce[0:20])

效果很好,显示如下:

然后当我需要从数据库中获取它时,我这样做:

rows, err := db.Query("SELECT nonce, time FROM noncestore WHERE endpoint=?", endpoint)

        var sTimeStamp, nonceHolder string
        for rows.Next() {
                err = rows.Scan(&nonceHolder, &sTimeStamp)
                errCheck(err)

Gives error//>> timeStamp, err := time.Parse(time.RFC3339, sTimeStamp)
                errCheck(err)

                if timeStamp == ts && nonceHolder == s {
                        return errors.New("Nonce already used")
                }

                if now.Sub(timeStamp) < *maxNonceAge {
                        _, err := db.Query("INSERT INTO noncestore SET nonce=?, time=?, endpoint=?", nonceHolder, sTimeStamp, endpoint)
                        errCheck(err)
                }
        }

上面提到的行给我这个错误:

2015/08/14 21:56:18 http: panic serving [::1]:49663: Failed: parsing time "2015-08-15 03:56:00" as "2006-01-02T15:04:05Z07:00": cannot parse " 03:56:00" as "T"

为什么能够将它转换为 RFC3339 并将其存储在数据库中,但是当需要获取它并将其格式化回 RFC3339 以便我可以在我的 if 语句出现错误?

您的数据库驱动程序似乎 returns 次采用的格式不在 RFC3339 中。而不是使用

timeStamp, err := time.Parse(time.RFC3339, sTimeStamp)

尝试使用

timeStamp, err := time.Parse("2006-01-02 15:04:05", sTimeStamp)

要记住的重要一点是数据库本身根本不会存储原始字符串,RFC3339 或其他。它有自己的时间内部表示,当您查询它时,您获得的值取决于该数据库希望如何将它重新发送给您。在这种情况下,它选择了一种稍微不同的格式,我在上面粘贴的格式字符串(以“2006-01-02 ...”开头的格式字符串)应该修复。是的,在 Go 中,日期格式字符串看起来像日期本身。