在不同的时区处理PHP服务器和MySQL服务器

对于那些使用标准共享托管软件包(如GoDaddy或网络解决方案)的用户,当托管服务器( PHP)和MysqL服务器位于不同的时区时,您如何处理日期时间转换?

此外,有没有人有一些最佳实践建议,以确定你的网站的访问者的时区是否在适当地操纵datetime变量?

PHP 5.1.0开始,您可以使用 date_default_timezone_set()功能设置脚本中所有日期/时间函数使用的认时区.

对于MysqL(引自MySQL Server Time Zone Support页)

Before MysqL 4.1.3,the server operates only in the system time zone set at startup. Beginning with MysqL 4.1.3,the server maintains several time zone settings,some of which can be modified at runtime.

您感兴趣的是每个连接设置的时区,您将在脚本的开头使用

SET timezone = 'Europe/London';

对于检测客户端时区设置,您可以使用一些JavaScript来获取并将该信息保存到cookie中,并在随后的页面读取中使用它来计算正确的时区.

//Returns the offset (time difference) between Greenwich Mean Time (GMT) 
//and local time of Date object,in minutes.
var offset = new Date().getTimezoneOffset(); 
document.cookie = 'timezoneOffset=' + escape(offset);

或者您可以向用户提供chioce自己设置他们的时区.

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...