一、背景。
时间戳就是计算当前与"1970-01-01 08:00:00"的时间差,在asp中通常是使用Datediff函数来计算两个日期差,代码:
timestamp=Datediff("s", "1970-01-01 08:00:00",now)
返回结果:1675951060
可以看到上面代码返回的是10位数,因为Datediff函数只能得到秒级的时间戳,无法计算毫秒时间差。里面的参数值“s”是表示秒,并没有“ms”的用法。而我们要的是毫秒级13位数的时间差,那怎么办呢?通过网络搜索和研究还是能找到些办法的。
二、解决方案
1.纯asp时间方案。
先上代码:
<%PublicFunctiongetTime()getTime=DateDiff("s", "1970-01-01 08:00:00", Date())*1000+Int(CDbl(Timer())*1000)EndFunctionresponse.writegetTime%>
返回结果:1675951060046
上面的办法很巧妙,就是对秒级时间戳打了个“补丁”,通过Timer()函数计算然后加上去。
2.通过调用js来实现。
这算是一个“旁门左道”的方法,在asp中调用js方法,这功能确实比较魔幻,一般人用的挺少但事实这样操作就是可以。
下面这个代码是我原创的,我了解到计算时间戳这种功能在js中算是非常平常的,于是研究了下便有了结果:
<scriptlanguage="JavaScript"runat="server">functiongetTimestamp(){eval("var s= new Date().getTime();");returns;}</script><%response.writegetTimestamp()%>
返回结果:1675951060048
可以看到返回的是13位的时间戳。
三、总结
将上面两个方法放一起运行得到结果相差几毫秒,这是正常的,毕竟代码运行也是要时间的。
计算毫秒级时间戳上面两个方法都可以,不过推荐使用asp自带的方法,即方法1,毕竟跨语言运行性能上可能会打折扣。
后续:
上面涉及到了在asp中写js代码。其实在asp环境中写asp代码还有另外一个方法,不过这个方法整个文件都得js代码,无法像上面那样混写,比如:
<%@Language="Javascript"%><%vars=newDate().getTime(); Response.Write (s); %>