我想知道一种好的、有效的方法来判断我的用户上次登录是多久前的事。
在用户个人资料中,我希望说明他们上次登录是多久前的事。
Eg:
用户1
上次登录:2小时前
用户2
上次登录:3 分钟前
用户3
上次登录:2 个月前
我将把他们最后的登录信息保存在 MySQL 数据库中,但想知道如何执行该脚本。
我刚刚意识到 Stackoverflow 使用了这个功能,这样可以帮助你理解我想要的东西。
mysql_query("UPDATE users SET lastactivity = ".time()." WHERE id = ".$userID);
这就是我更新数据库的方式。
每个页面请求仅更新其最后的活动。
<?php
mysql_query("UPDATE users SET lastactivity = ".time()." WHERE id = ".$userID);
要显示他们上次在线的时间,只需从数据库中选择他们的最后活动字段并显示它
<?php
$activity = mysql_result(mysql_query("SELECT lastactivity FROM users WHERE id = ".$userID), 0);
echo "Last activity: ".relativeTime($active);
where relativeTime()
是我一直在使用的函数:
function relativeTime($time, $short = false){
$SECOND = 1;
$MINUTE = 60 * $SECOND;
$HOUR = 60 * $MINUTE;
$DAY = 24 * $HOUR;
$MONTH = 30 * $DAY;
$before = time() - $time;
if ($before < 0)
{
return "not yet";
}
if ($short){
if ($before < 1 * $MINUTE)
{
return ($before <5) ? "just now" : $before . " ago";
}
if ($before < 2 * $MINUTE)
{
return "1m ago";
}
if ($before < 45 * $MINUTE)
{
return floor($before / 60) . "m ago";
}
if ($before < 90 * $MINUTE)
{
return "1h ago";
}
if ($before < 24 * $HOUR)
{
return floor($before / 60 / 60). "h ago";
}
if ($before < 48 * $HOUR)
{
return "1d ago";
}
if ($before < 30 * $DAY)
{
return floor($before / 60 / 60 / 24) . "d ago";
}
if ($before < 12 * $MONTH)
{
$months = floor($before / 60 / 60 / 24 / 30);
return $months <= 1 ? "1mo ago" : $months . "mo ago";
}
else
{
$years = floor ($before / 60 / 60 / 24 / 30 / 12);
return $years <= 1 ? "1y ago" : $years."y ago";
}
}
if ($before < 1 * $MINUTE)
{
return ($before <= 1) ? "just now" : $before . " seconds ago";
}
if ($before < 2 * $MINUTE)
{
return "a minute ago";
}
if ($before < 45 * $MINUTE)
{
return floor($before / 60) . " minutes ago";
}
if ($before < 90 * $MINUTE)
{
return "an hour ago";
}
if ($before < 24 * $HOUR)
{
return (floor($before / 60 / 60) == 1 ? 'about an hour' : floor($before / 60 / 60).' hours'). " ago";
}
if ($before < 48 * $HOUR)
{
return "yesterday";
}
if ($before < 30 * $DAY)
{
return floor($before / 60 / 60 / 24) . " days ago";
}
if ($before < 12 * $MONTH)
{
$months = floor($before / 60 / 60 / 24 / 30);
return $months <= 1 ? "one month ago" : $months . " months ago";
}
else
{
$years = floor ($before / 60 / 60 / 24 / 30 / 12);
return $years <= 1 ? "one year ago" : $years." years ago";
}
return "$time";
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)