基本上,我一直在尝试按照教程来创建聊天室。
Ajax Web Chat Tutorial
我已经完成了所有的工作,除了时间显示不正确,我不知道从哪里开始。
步骤1.聊天立即显示用户的行(使用javascript的Date()正确显示,因此用户认为系统速度很快)
步骤2.然后,它转到数据库并存储聊天行,其中列“ts”将current_timestamp存储为时间戳。
步骤3.在Ajax从数据库中获取聊天记录并刷新聊天记录以显示“真实”聊天记录后,即使代码应该将聊天记录转换为用户的时区,聊天记录也无法正确显示。下面的代码可以让你对我所处的位置有一个大致的了解。
chat数据库抓取时间: //返回创建聊天的GMT (UTC)时间:
$chat->time = array(
'hours' => gmdate('h',strtotime($chat->ts)),
'minutes' => gmdate('i',strtotime($chat->ts))
);然后将其发送到javascript以更新聊天室的聊天行
//所有时间都显示在用户的时区var d= new Date();
if(params.time) {
// PHP returns the time in UTC (GMT). We use it to feed the date
// object and later output it in the user's timezone. JavaScript
// internally converts it for us.
d.setUTCHours(params.time.hours,params.time.minutes);
}
params.time = (d.getHours() < 10 ? '0' : '' ) + d.getHours()+':'+
(d.getMinutes() < 10 ? '0':'') + d.getMinutes();示例:用户提交聊天线路..
Javascript打印11:07...
SQL将current_timestamp保存为8:07 ...
PHP从数据库抓取并将其转换为12:07
d.setUTCHours = 1348834072033
最后使用javascript将params.time打印到8:07
我不认为我错过了任何其他的东西。有人能帮上忙吗?在这几天里,我真的感觉很糟糕。Javascript很好..。我认为SQL正在做它应该做的事情,并将其转换为通用时间或GMT?:P和PHP非常接近。一个小时后,javascript没有完成它应该做的事情:(
发布于 2012-09-28 23:27:24
这里有,什么,三个不同的系统?web浏览器、数据库和web服务器(运行PHP),对吗?
它们是否同步?它们的配置是否正确?这就是您应该开始的地方。
http://en.wikipedia.org/wiki/Ntpd
https://dev.mysql.com/doc/refman/5.5/en/time-zone-support.html
http://php.net/manual/en/datetime.configuration.php
https://stackoverflow.com/questions/12642773
复制相似问题