全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

利用Laravel事件系统如何实现登录日志的记录详解

本文介绍的是利用Laravel事件系统实现登录日志记录的相关内容,分享出来给大家参考,下面来看看详细的介绍:

明确需求

记录一个登录日志,通常需要下列信息:

  • 客户端Agent信息
  • 客户端IP地址
  • 访问IP地点
  • 登录时间
  • 登录用户信息

确立工具

明确完需求后,根据每个需求查找自己所需的工具吧。

  • 需求1 jenssegers/agent就可以满足我们要求
  • 需求2 Laravel下直接Request::getClientIp()
  • 需求3 zhuzhichao/ip-location-zh这个包可以满足要求
  • 需求4 time()
  • 需求5 登录用户模型

开工

采用Laravel的事件订阅系统来实现,需要实现一个登录事件和一个登录事件监听器。

生成事件和监听器

Laravel命令行支持自动生成事件和监听器,在App\Providers\EventServiceProvider中添加需要实现的事件:

protected $listen = [ 
  ...,
  //添加登录事件及对应监听器,一个事件可绑定多个监听器
  'App\Events\LoginEvent' => [
  'App\Listeners\LoginListener',
 ],
];

运行命令:php artisan event:generate就会自动生成事件和监听器,已存在的事件和监听器不会发生改变。

登录事件(Event)

回顾下需求,我们的登录事件需要的5点信息,在事件中需要记录这些信息,所以事件设计如下:

namespace App\Events;

use Illuminate\Broadcasting\Channel; 
use Illuminate\Queue\SerializesModels; 
use Illuminate\Broadcasting\PrivateChannel; 
use Illuminate\Foundation\Events\Dispatchable; 
use Illuminate\Broadcasting\InteractsWithSockets;

use App\Models\User; 
use Jenssegers\Agent\Agent;

class LoginEvent 
{
 use Dispatchable, InteractsWithSockets, SerializesModels;

 /**
 * @var User 用户模型
 */
 protected $user;

 /**
 * @var Agent Agent对象
 */
 protected $agent;

 /**
 * @var string IP地址
 */
 protected $ip;

 /**
 * @var int 登录时间戳
 */
 protected $timestamp;

 /**
 * 实例化事件时传递这些信息
 */
 public function __construct($user, $agent, $ip, $timestamp)
 {
 $this->user = $user;
 $this->agent = $agent;
 $this->ip = $ip;
 $this->timestamp = $timestamp;
 }

 public function getUser()
 {
 return $this->user;
 }

 public function getAgent()
 {
 return $this->agent;
 }

 public function getIp()
 {
 return $this->ip;
 }

 public function getTimestamp()
 {
 return $this->timestamp;
 }

 /**
 * Get the channels the event should broadcast on.
 *
 * @return Channel|array
 */
 public function broadcastOn()
 {
 return new PrivateChannel('channel-default');
 }
} 

在事件中记录所需要的信息,并实现这些信息的get方法。

登录监听器(Listener)

在监听器中,获取到事件传递过来的信息,把这些信息记录到数据库中,实现如下:

namespace App\Listeners;

use App\Events\LoginEvent;

class LoginListener 
{

 // handle方法中处理事件
 public function handle(LoginEvent $event)
 {
 //获取事件中保存的信息
 $user = $event->getUser();
 $agent = $event->getAgent();
 $ip = $event->getIp();
 $timestamp = $event->getTimestamp();

 //登录信息
 $login_info = [
  'ip' => $ip,
  'login_time' => $timestamp,
  'user_id' => $user->id
 ];

 // zhuzhichao/ip-location-zh 包含的方法获取ip地理位置
 $addresses = \Ip::find($ip);
 $login_info['address'] = implode(' ', $addresses);

 // jenssegers/agent 的方法来提取agent信息
 $login_info['device'] = $agent->device(); //设备名称
 $browser = $agent->browser();  
 $login_info['browser'] = $browser . ' ' . $agent->version($browser); //浏览器
 $platform = $agent->platform();
 $login_info['platform'] = $platform . ' ' . $agent->version($platform); //操作系统
 $login_info['language'] = implode(',', $agent->languages()); //语言
 //设备类型
 if ($agent->isTablet()) {
  // 平板
  $login_info['device_type'] = 'tablet';
 } else if ($agent->isMobile()) {
  // 便捷设备
  $login_info['device_type'] = 'mobile';
 } else if ($agent->isRobot()) {
  // 爬虫机器人
  $login_info['device_type'] = 'robot';
  $login_info['device'] = $agent->robot(); //机器人名称
 } else {
  // 桌面设备
  $login_info['device_type'] = 'desktop';
 }

 //插入到数据库
 DB::table('login_log')->insert($login_info);

 } 
}

这样,监听器就完成了,每次一触发登录事件,就会在数据库中添加一条登录信息。

触发事件

通过全局的event()方法来触发事件,event()方法的参数为事件实例:

namespace App\Controllers; 
...
use App\Events\LoginEvent; 
use Jenssegers\Agent\Agent; 
class AuthControoler extends Controller 
{
 ...
 public function login(Request $request)
 {
 //登录实现
 ...
 //登录成功,触发事件
 event(new LoginEvent($this->guard()->user(), new Agent(), \Request::getClientIp(), time()));
 ... 
 } 
} 

队列化监听器

有时监听器会进行一些耗时操作,这时应该结合Laravel的队列系统将监听器进行队列化,前提是已经配置了队列并开启了队列处理器。

队列化非常简单,只需监听器实现ShouldQueue接口即可,即:

namespace App\Listeners; 
...
use Illuminate\Contracts\Queue\ShouldQueue; 
class LoginListener implements ShouldQueue 
{
 /**
 * 失败重试次数
 * @var int
 */
 public $tries = 1;
 ...
} 

总结

Laravel的事件系统实现起来还是非常优雅的,同一个事件可以很方便的添加各类监听器,且各个监听器之间互不干扰,解耦性非常强。加上队列系统,可以很方便的处理一些后续任务。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# laravel  # 日志记录  # laravel5.3登录日志  # 事件  # Laravel实现用户注册和登录  # Laravel搭建后台登录系统步骤详解  # Laravel 自带的Auth验证登录方法  # Laravel 5.4重新登录实现跳转到登录前页面的原理和方法  # Laravel重写用户登录简单示例  # SSO单点登录的PHP实现方法(Laravel框架)  # Laravel5.2使用Captcha生成验证码实现登录(session巨坑)  # php的laravel框架快速集成微信登录的方法  # laravel5.2实现区分前后台用户登录的方法  # Laravel登录失败次数限制的实现方法  # 方法来  # 很方便  # 数据库中  # 自动生成  # 事件中  # 的是  # 客户端  # 系统实现  # 就会  # 好了  # 相关内容  # 多个  # 只需  # 会在  # 所需  # 给大家  # 来看看  # 就可  # 这篇文章  # 谢谢大家 


相关文章: 建站之星安装后如何配置SEO及设计样式?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  教学论文网站制作软件有哪些,写论文用什么软件 ?  公众号网站制作网页,微信公众号怎么制作?  网站制作知乎推荐,想做自己的网站用什么工具比较好?  建站之星安装后如何自定义网站颜色与字体?  学校建站服务器如何选型才能满足性能需求?  网站按钮制作软件,如何实现网页中按钮的自动点击?  常州企业建站如何选择最佳模板?  如何在万网主机上快速搭建网站?  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  网站制作的步骤包括,正确网址格式怎么写?  linux top下的 minerd 木马清除方法  如何在服务器上配置二级域名建站?  如何在Golang中指定模块版本_使用go.mod控制版本号  C#怎么使用委托和事件 C# delegate与event编程方法  宝塔建站后网页无法访问如何解决?  ,怎么用自己头像做动态表情包?  南京网站制作费用,南京远驱官方网站?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  如何用VPS主机快速搭建个人网站?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  外汇网站制作流程,如何在工商银行网站上做外汇买卖?  如何用好域名打造高点击率的自主建站?  济南网站建设制作公司,室内设计网站一般都有哪些功能?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  建站之星价格显示格式升级,你的预算足够吗?  如何在阿里云香港服务器快速搭建网站?  潮流网站制作头像软件下载,适合母子的网名有哪些?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  如何彻底卸载建站之星软件?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  建站VPS选购需注意哪些关键参数?  孙琪峥织梦建站教程如何优化数据库安全?  建站之星伪静态规则如何设置?  如何制作一个表白网站视频,关于勇敢表白的小标题?  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  如何快速完成中国万网建站详细流程?  建站之星导航配置指南:自助建站与SEO优化全解析  实例解析Array和String方法  建站主机如何选?性能与价格怎样平衡?  如何选择服务器才能高效搭建专属网站?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  建站之星后台管理系统如何操作?  清单制作人网站有哪些,近日“兴风作浪的姑奶奶”引起很多人的关注这是什么事情?  南宁网站建设制作定制,南宁网站建设可以定制吗?  建站上传速度慢?如何优化加速网站加载效率?  如何用低价快速搭建高质量网站?  如何用西部建站助手快速创建专业网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。