Laravel 5.2登录事件处理

Per*_*ika 3 php events login laravel laravel-5.2

在数据库中,我有一个表last_login_at列的用户.每当有一些用户登录时 - 我想提升last_login_at.

所以,我创建了app/Listeners/UpdateLastLoginOnLogin.php:

namespace App\Listeners;

use Carbon\Carbon;

class UpdateLastLoginOnLogin
{
    public function handle($user, $remember)
    {
        $user->last_login_at = Carbon::now();

        $user->save();
    }
}
Run Code Online (Sandbox Code Playgroud)

在app/Providers/EventServiceProvider中:

    protected $listen = [
        'auth.login' => [
            'App\Listeners\UpdateLastLoginOnLogin',
        ],
    ];
Run Code Online (Sandbox Code Playgroud)

但这不起作用,事件未得到处理.这里已经提到了同样的问题:Laravel 5.2登录但没有解决方案的EventServiceProvider映射.我试过这样做:

...

use Illuminate\Auth\Events\Login;

class UpdateLastLoginOnLogin
{
    public function handle(Login $event)
    {
        $event->user->last_login_at = Carbon::now();
        $event->user->save();
    }
}
Run Code Online (Sandbox Code Playgroud)

和:

protected $listen = [
    'Illuminate\Auth\Events\Login' => [
        'App\Listeners\UpdateLastLoginOnLogin',
    ],
];
Run Code Online (Sandbox Code Playgroud)

但它不起作用.

另外,我检查了这个:https://laracasts.com/discuss/channels/general-discussion/login-event-handling-in-laravel-5但是php artiasn clear-compiled没有解决问题.

编辑:其他细节,这里与项目的链接实际上完全相同(它以相同的方式完成):https://github.com/tutsplus/build-a-cms-with-laravel

小智 12

你几乎就在那里,只是进行了一些更改,用于身份验证的事件和监听器在Laravel 5.2中发生了一些变化:UpdateLastLoginOnLogin中的handle方法应该只有一个事件作为参数

namespace App\Listeners;

use Carbon\Carbon;
use Auth;

class UpdateLastLoginOnLogin
{
    public function handle($event)
    {
        $user = Auth::user();
        $user->last_login_at = Carbon::now();
        $user->save();
    }
}
Run Code Online (Sandbox Code Playgroud)

对于EventServiceProvider,您可以像这样指定监听器:

protected $listen = [
    'Illuminate\Auth\Events\Login' => [
        'App\Listeners\UpdateLastLoginOnLogin@handle',
    ],
];
Run Code Online (Sandbox Code Playgroud)