最近在整合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是最好的解决方案。
发表回复