最近在整合VOIP电话(供应商称为云电话)到奇客大师(GeekerMaster)系统,返回的log说是时间戳错误。供应商说每次post的url的时效性是1分钟,检查发现后,我们每次发送Post请求的时候都会重新产生一遍,应该不存在时间过期的问题。

用 _logger.warning记录更多参数,发现在计算post的url时的时间是不对的,比当前电脑时间早了8个小时。而在系统端用date查询时间是正确的。应该是Odoo系统采用UTC时间的问题,Odoo系统前端显示是当前自己时区的时间,后台数据库用的是UTC时间,据说这是解决全球性使用一个系统的时间差问题的最好方法。

但是国内的供应商用的是北京时间UTC+8时区,所以只好着手解决了:

Odoo调整时差方法一

import datetime
from datetime import timedelta

now = (datetime.datetime.now() + timedelta(hours=8)).strftime("%Y%m%d%H%M%S")

直接加8个小时,直观又方便。后面的时间格式根据要求可以更改。

Odoo调整时差方法二

import datetime
import pytz

user_tz = self.env.user.tz
# local_tz = pytz.timezone(user_tz)
now = datetime.datetime.now(pytz.timezone(
            user_tz)).strftime("%Y%m%d%H%M%S")

前提要在个人配置里设置对你自己的时区,否则无法读取。

这里有个小提示: strftime和 strptime是不同的,一个是输出显示时间的样式,后者是输出时间的格式。

ITGeeker技术奇客最近也调试了阿里云的短信,阿里用的时间格式就和时差无关,用的GMT时间。分享一下用python实现阿里短信所需要的时间格式吧:

import time

now = time.strftime("%Y-%m-%dT%H:%M:%SZ", time.gmtime())

UTC确立以后UTC(GMT)=UTC(+0)作为一般提到的世界时,GMT表示零时区的时刻。 … 格林威治时间(GMT)是一个比较模糊的概念。 在1928年,GMT就是世界时。 在UTC被广泛采用后,我们提到的GMT实际上是UTC时间,或者说零时区的标准时。

所以说用UTC是最好的解决方案。

留下评论

电子邮件地址不会被公开。 必填项已用*标注