Часы с единым временем
<script type="text/javascript"> function moscowTime() { var d = new Date(); d.setHours( d.getHours() + 3, d.getMinutes() + d.getTimezoneOffset() ); return d.toTimeString().substring(0,8); } onload = function () { setInterval(function () { document.getElementById("txt").innerHTML = moscowTime(); }, 100); } </script> Хочу поставить часы на сайт, но чтобы у всех было единое время, использую код, но с ним такое не получается, как я понимаю препятствует new Date(); соотвественно если я на компе время поменяю, оно и там изменится, как этому можно препятствовать? |
Серверное время передавай.
|
а поподробнее можно?
|
singmen, если требуется синхронизировать чеса клиентов по времени сервера, то отдавайте в JS смещение временной зоны сервера, на которую корректировать смещение клиента - часы у клиентов будут идти по времени сервера. Как передать это смещение, зависит от серверного языка. На РНР, это так:
date("Z"); //в секундах со знаком |
сделал в таком виде:
<span id="vern_time"> <? echo date("H").":"; echo date("i").":"; echo date("s"); ?></span> <script> setInterval(function () {$('#tm').load('/do/time.php #vern_time');}, 100); </script> <span id="tm"></span> но получается таким образом я ддосю сервер, бывает за 6-12 секунд за раз прыгает |
Не так. Смещение временной зоны на клиенте возвращается в минутах, на сервере, если РНР, в секундах.
Если у вас РНР, отдавая страницу клиенту дописывайте в конце нее (перед закрывающим тегом body): <script>var sZone = <?=date("Z") * 1000?></script> Сервер и клиент возвращают смещение часового пояса с разными знаками по разную сторону от Гринвича. Поэтому плюсуя к смещению клиента смещение сервера получаем смещение на которое нужно скорректировать часы клиента, например: var Zone = new Date().getTimezoneOffset() * 60 * 1000 + sZone; var watch = new Date((new Date).getTime() + Zone); //время которое устанавливается в часах |
Цитата:
Можно взять и таймштамп серверного времени, корректировать его каждую секунду, открывать дату по этому времени. singmen, <html> <head> </head> <body> <div id="times"></div> <!--Contents--> <script>//var zO = new Date().getTimezoneOffset() * 60 * 1000 + <?=date("Z") * 1000?>; //это должно быть реально в скрипте var zO = new Date().getTimezoneOffset() * 60 * 1000 + 10800000; //а это для действующего примера, по Москве, удалить из реального скрипта function watch() { var d = new Date((new Date).getTime() + zO), t = d.getMinutes(), locale = 'ru-RU', options = {year: 'numeric', month: 'long', day: 'numeric'}; return { dY : d.getFullYear(), dM : d.getMonth() + 1, dD : d.getDate(), sD : d.toLocaleDateString(locale, options), //локальное представление даты, поддержка locale и options: FF 29, IE 11, Opera 15, в Safari нет поддержки русской локали tH : d.getHours(), tM : t < 10 ? "0"+t : t, tS : d.getSeconds() } } function outTime() { var t = watch(); //объект значений текущего времени //выводим во что-то время document.getElementById('times').innerHTML = '<pre>' + t.sD + ' ' + t.tH + (t.tS & 1 ? ':' : ' ') + t.tM + '</pre>'; setTimeout(outTime, 1000); } outTime(); </script> </body> </html> |
Цитата:
|
Цитата:
Если же нужна проверка чего-то от "накрутили", то нужны не просто часы на клиенте, а запрашивать у клиента его часовой пояс и делать проверку на сервере, ибо подкрутить можно что угодно, хоть используя Date, хоть математику с цифрами, и уж если на то пошло, то просто слать сервером без всякого клиента лабуду. Ну это же не серьезно. ) |
Цитата:
|
Часовой пояс GMT +3, время: 15:46. |