douxieqiu0651 2015-09-29 17:31
浏览 48
已采纳

Laravel 4.2 - 使用Event时用户会话超时时无法更新我的数据库

I currently have a problem with my laravel(4.2) app.

I want to update my database when the user is offline by the end of session (Automatic).

So I put the lifetime session to 1 minute for testing.

I create an event file :

<?php

Event::listen('auth.login', function($user)
{
    $user->is_online        = 1;
    $user->save();
});

Event::listen('auth.logout', function($user)
{
    $user->is_online        = 0;
    $user->save();
});

Everything works perfectly when I log in or log out manually but when I get automatically disconnected by the end of the session it does not work.

If you have an idea I would appreciate

Thanks.

  • 写回答

2条回答 默认 最新

  • dongyuan2652 2015-09-29 17:51
    关注

    You cannot detect when a user closes their browser or navigates off your site using PHP

    Instead, your best bet is most likely to store each user's last activity time.

    Create a column in your user table along the lines of 'last_activity'. Whenever a user loads a page, update their last_activity to the current time. To get a list of who's online, just query the database for users with last_activity values more recent than 10 min or 20 min.

    you can set session time using this

    $_SESSION['time'] = time();

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 phython如何实现以下功能?查找同一用户名的消费金额合并—
  • ¥15 孟德尔随机化怎样画共定位分析图
  • ¥18 模拟电路问题解答有偿速度
  • ¥15 CST仿真别人的模型结果仿真结果S参数完全不对
  • ¥15 误删注册表文件致win10无法开启
  • ¥15 请问在阿里云服务器中怎么利用数据库制作网站
  • ¥60 ESP32怎么烧录自启动程序
  • ¥50 html2canvas超出滚动条不显示
  • ¥15 java业务性能问题求解(sql,业务设计相关)
  • ¥15 52810 尾椎c三个a 写蓝牙地址