javascript没有计算时间减法的正确输出

问题描述

我在尝试将 JavaScript 与我们的监控工具集成时遇到问题。对此进行了大量搜索,但似乎无法找到我哪里出错的答案。如果可能的话,真的会很感激任何帮助。

我们有一个第三方 .json 页面 URL,它每 5 分钟更新一次并以这种格式返回日期/时间戳:

“2021-07-06 10:13:58”

我们有一个 javascript,它试图解析这个日期/时间,检查当前时间,然后减去两次。如果当前时间自 .json 页面时间起超过 30 秒,则会生成警报。

到目前为止,我对脚本进行了一些更改,这是我的最新版本...

var responseBody = response.getResponseBody();
var myObj = JSON.parse(responseBody);
var time = myObj.updated;
var amendedTime = time.replace(' ','T');

var respTime = Date.parse(amendedTime);
var curTime = Date.Now();
var delta = respTime - curTime;

if (delta > 3000)
{
   api.info("Time has not updated in the last 30 seconds " + delta);
   api.fail("Time has not updated in the last 30 seconds " + delta);
}

我上次跑步的例子

  • .json 页面上的日期/时间是 2021-07-06 10:13:58
  • 脚本运行时间为 10:17
  • 脚本运行的响应/输出为:“过去 30 秒内时间未更新 3344037”

毫秒转换为 55 分钟,这显然比预期的增量多得多,因此应该会看到类似 182000 / 182 秒的数据。

所以不确定为什么输出返回的时间差要大得多,并认为我的 var curTime 行可能有问题?

谢谢

解决方法

您必须考虑时区。 Date.now() 与 UTC 时区相关联,而您的回复不是。

你的数学也需要被尊重:

var delta = curTime - respTime;

鉴于您提供的代码以及您认为它使用的时间,您的增量将是一个负数(这就是您可以告诉您正在使用不同时区的方式)。

从外观上看,您可能只需在“当前时间”上增加一个小时(见下文)就可以逃脱,但这绝对不是一个好习惯,我强烈建议您不要再使用它了比测试。

var delta = (curTime + 3_600_000) - respTime;

还应该注意的是,您的条件是针对 3 秒而不是 30 秒进行测试,添加一个额外的零:30_000

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...