Php 当用户成功使用Laravel登录时,如何更新上次登录列?
当用户成功登录时,我尝试更新最后一个登录列,我尝试将下面的代码放入LoginController,但不起作用,我也尝试了一个侦听器,跟随,但不起作用,什么都没有发生,似乎侦听器没有被执行Php 当用户成功使用Laravel登录时,如何更新上次登录列?,php,laravel,Php,Laravel,当用户成功登录时,我尝试更新最后一个登录列,我尝试将下面的代码放入LoginController,但不起作用,我也尝试了一个侦听器,跟随,但不起作用,什么都没有发生,似乎侦听器没有被执行 DB::table('users') ->where('id', Auth::id()) ->update(['lastlogin' => Carbon::now()]); 我的laravel版本是5.4.12。如何使其
DB::table('users')
->where('id', Auth::id())
->update(['lastlogin' => Carbon::now()]);
我的laravel版本是5.4.12。如何使其工作?您可以订阅用户成功通过身份验证后激发的
登录事件
在app/providers/EventServiceProvider.php
中,将事件和侦听器添加到$listen
数组中
protected $listen = [
// ...
\Illuminate\Auth\Events\Login::class => [
\App\Listeners\LastLogin::class,
],
// ...
];
在app/listeners/LastLogin.php
namespace App\Listeners;
use App\Models\User;
use Carbon\Carbon;
use Illuminate\Auth\Events\Login;
class LastLogin
{
/**
* Handle the event.
*
* @param \Illuminate\Auth\Events\Login $event
* @return void
*/
public function handle(Login $event)
{
// Update user last login date/time
$event->user->update(['lastlogin' => Carbon::now()]);
}
}
我就是这样解决的。我还添加了一个登录计数,以这种方式检查用户活动:$event->user->login\u count=$event->user->login\u count+1;是的,如果你想增加一个登录计数器,我会使用下面的方法来保持良好的状态<代码>$event->user->increment('login_count')->update(['lastlogin'=>Carbon::now())代码>谢谢,它工作得很好,唯一不同的是我使用这个查询来更新:DB::table('users')->where('id',$event->user->id)->update(['lastlogin'=>Carbon::now())
,出于某种奇怪的原因,您使用的方式对我不起作用。没有错误,但它没有更新最后一个登录列。您的模型上的属性是可填充的还是不受保护的?