1

我有 3 个变量来跟踪在网站上花费的时间

 $_SESSION['checkin']; //logged when user first enters the site 
 $_SESSION['loggedAt']; //logged when the user leaves the site
 $_SESSION['timespent']; //time spent in minutes

我想做的是每次用户离开页面时,这些值都会被推送到数据库中。我所做的是使用onbeforeunload。

下面是我如何使用它:

在每一页上:

 <script type="text/javascript" src="js/storeSession.js"></script>

storeSession.js:

window.onbeforeunload = confirmExit();
  function confirmExit()
  {
        var xhr = new XMLHttpRequest();
        xhr.open('post','../php/storeSession.php',true);
        xhr.send();
        return "Are you sure you want to leave?";
  }

和 storeSession.php:

$_SESSION['loggedAt'] = time();
$temptime = (double)$_SESSION['timespent']/60;
$_SESSION['timespent'] = $_SESSION['loggedAt'] - $_SESSION['checkin'];

mysql_select_db($db, $conn) or die(mysql_error()); 

$data = mysql_query("INSERT INTO user (user_id, timespent) VALUES ($tempuser, $temptime) ON DUPLICATE KEY UPDATE timespent = timespent + $temptime")
        or die(mysql_error()); 

$_SESSION['timespent'] = null;
$_SESSION['loggedAt'] = null;
$_SESSION['checkin'] = null;

mysql_close($con);

我找不到问题,一切似乎都正常(没有错误等)。有人有什么主意吗?

4

3 回答 3

2

一个问题是这一行:

window.onbeforeunload = confirmExit();

您调用了函数并将返回值分配给window.onbeforeunload,而不是分配函数本身。

将行更改为:

window.onbeforeunload = confirmExit;

...或使用闭包。

此外,您在不发送任何数据的情况下发出 POST 请求(您没有将任何内容传递给 的第一个参数send()) - 您可能希望改为发出 GET 请求。

于 2012-12-18T11:33:46.037 回答
1

您需要从 onbefore 函数中删除括号

window.onbeforeunload = confirmExit;

此外,您将在确认之前通过 XHR 呼叫结束会话。如果用户取消卸载,他仍然处于注销状态。

于 2012-12-18T11:37:25.110 回答
0

您是否尝试过使用onunload而不是onbeforeunload. 我记得后一个是受限制的,因为它可能被用来阻止用户退出页面(甚至是浏览器)。我不完全确定,但我认为(大多数)浏览器只读取返回的字符串并忽略其余部分。

另外,我自己在 on(before)unload 操作上遇到了一些问题,并通过显式使用与服务器的同步通信来解决这些问题(我使用了 jquery + ajax),否则 ajax 请求没有完成(尽管我没有经验XMLHttpRequest,但我认为这个选项应该是可比的)

于 2012-12-18T11:57:24.527 回答