- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
如果没有丢失或增加的小时数,此测试通常全年都可以通过。但现在这很麻烦。我们正在验证到期日期 getExp()
减去 7 天,在发行日期 getIss()
的 10 毫秒内。由于 exp
和 iss
值是紧接着彼此生成的,因此 10 毫秒是一个完全可以接受的增量,以期望值介于两者之间。
但是当 Java 日期代码在初始化新的 JWT 声明后调用 setExp()
时,现在可以理解的是,当展望 future 一周时,他们可以休息一个小时。
断言/测试代码:
assertThat(claim.getExp()).isCloseTo(new DateTime(claim.getIss()).plusDays(7).toDate(), 10);
英文是这样写的:断言 claim 的到期日期在 claim 签发日期的 10 毫秒 + 7 天之内。
一个直接的解决方法是将一个小时的毫秒值添加到允许的增量中,但我很好奇是否有更好的解决方案。
编辑:我相信我找到了问题所在。我们使用 ZonedDateTime.now() 初始化 claim 签发日期和 claim 到期日期:
Claim claim = new Claim();
claim.setIss(Date.from(ZonedDateTime.now(ZoneId.of("UTC")).toInstant()));
claim.setExp(Date.from(ZonedDateTime.now(ZoneId.of("UTC")).plusDays(7).toInstant()));
但是当我们使用 JODA 时间进行验证时,我们假设我们的本地夏令时规则。这显然会导致 GMT DST 与美国 DST 规则出现问题。
EDIT2:修复涉及 2 个单词并更新单元测试以遵守 UTC:
assertThat(claim.getExp()).isCloseTo(new DateTime(claim.getIss(), DateTimeZone.UTC).plusDays(7).toDate(), 10);
最佳答案
您仅有的两个解决方案是:
更改您的报告,以便使用 UTC(即纪元 unix 时间)而不是基于本地时间。从技术角度来看,这是更可取的解决方案,因为它是一个全局标准,包括大多数共享服务器和数据源;无需担心夏令时;你仍然可以让你的报告计算本地时间。
或者,查找或添加可靠的“dateadd”类型的函数,将夏令时考虑在内。
令我惊讶的是,所有平台都没有内置该功能。诚然,DST 有一套令人困惑的、不断发展的规则,这些规则是特定于地区的(按大陆、国家,有些地区按“州”甚至“县”)……但仍然如此。
目前,在北美大部分地区,夏令时:
开始三月的第二个星期日。 (“Spring Forward”所以时钟从 01:59 变为 03:00)
在 11 月的第一个星期日结束。 (“后退”从 01:59 到 01:00)
Windows API 具有计算 DST 是否有效的功能,但实际上,任何应用程序都不应允许应用程序显示,例如在北美:“2018 年 3 月 11 日星期日 02:30:00”因为 那个时间不存在。
...仍然,#1 是您的首选解决方案,因为准确性和标准化更加直接。
关于java - 由于夏令时,JWT 发行日期与到期日期检查失败。什么是全年无休的解决方案?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49141695/
举个例子,让我们使用以下 cron 表达式:“0 0 14 1 * ?” -> 在每月第一天的 14:00 触发。 我使用 Quartz CronScheduleBuilder 来构建表达式,但这无关
由于某种原因,夏令时开始时,我的一个网站在午夜 12:00 自动发布,从晚上 11:00 开始发布。有什么方法可以设置 MySQL 服务器变量以正确处理夏令时更改吗? 最佳答案 请提供... SHOW
如何检查夏令时是否生效? 最佳答案 您可以使用time.localtime并查看返回值中的 tm_isdst 标志。 >>> import time >>> time.localtime() (201
我有一个奇怪的问题: 我从 mysql 数据库中获取一些数据,我将这些数据用 strotime 转换为时间戳。然后我将这些时间戳与 for 循环进行比较: for ($i=$start;$imodif
如何检查夏令时是否有效? 最佳答案 您可以使用 time.localtime并查看返回值中的 tm_isdst 标志。 >>> import time >>> time.localtime() (20
我使用以下代码在文件中生成日期: echo "DTSTART;TZID=" . date_default_timezone_get() . ":" . strftime('%Y%m%d', strto
在下面,为什么 to_char() 中不包含夏令时?我怎样才能获得夏令时的时间? SELECT systimestamp AT TIME ZONE 'Australia/Adelaide' from
以下是连续两天之间的小时数计算: (AbsoluteTime[{2011, 3, 14}] - AbsoluteTime[{2011, 3, 13}]) / 3600 因此,您可能不会对 Mathem
function DateTimeToFileTime(FileTime: TDateTime): TFileTime; var LocalFileTime, Ft: TFileTime; S
我制作了一个小代码片段。告诉你几岁,精确到秒。 但是我发现了一些奇怪的事情。我知道时间和时区是工作的噩梦,但这是在我自己的国家和时区内,所以我有点困惑。 如果我输入日期。 27-12-2013(dd-
在 Jenkins 的夜间构建中,我们的一项测试在凌晨 2:00:12 失败。经过一段时间的调试和更改计算机的系统时间后,我感到非常困惑。然后我写了下面的测试(模拟问题),它失败了,但我不明白为什么。
linux如何处理夏令时(DST) 切换是否立即发生,例如 3 点钟立即切换到 2 点钟?或者变化缓慢我问你这个是因为我的服务器上有很大的日期基础,如果这个切换在数据库中的条目上立即发生一小时,将会
我正在使用 NSDate 格式化程序从 Facebook Graph API 请求(格林威治标准时间)获取日期并将其转换为用户的本地时区。我可以很好地读取日期并设置它的新时区,但是当我打印出新日期时,
我的 API 使用 ISO 8601 向客户端表示时间。我们有一个功能,我们希望显示它来自哪个时区。通过纯粹存储时区偏移,我们正在失去对细节的跟踪。 即,犹他州和亚利桑那州遵守 MST -06:00半
PHP代码 $t = strtotime( '2012-09-21T03:00:00+00:00 America/Chicago' ); $t2 = date('c',$t); echo $t2;
PHP代码 $t = strtotime( '2012-09-21T03:00:00+00:00 America/Chicago' ); $t2 = date('c',$t); echo $t2;
我有这个问题。我有这个格式的日期 var datestring = "2017-10-30T15:03:10.933044Z"; 如果我这样写代码 var d = new Date(datestrin
每当日光切换发生时,我都会触发事件。 我知道何时会发生 Spring /秋季切换 TimeZone.CurrentTimeZone.GetDaylightChanges(year) 这会返回 2 个日
我正在开发一个关心夏令时变化的关键应用程序。 我试图通过比较跨越夏令时变化的日期来手动模拟运行时可能发生的情况,因此我进行了以下测试。我当前所在的位置是意大利,因此今年从 CEST(中欧夏令时)更改为
我有这个应用程序,它将当前日期与来自 xml 文件的已解析日期进行比较: Date timeDiff = new Date(date.getTime() - new Date().getTime())
我是一名优秀的程序员,十分优秀!