1. <output id="hzk7v"><pre id="hzk7v"><address id="hzk7v"></address></pre></output>
      <output id="hzk7v"></output>
    2. <nav id="hzk7v"><i id="hzk7v"><em id="hzk7v"></em></i></nav>
    3. <listing id="hzk7v"><delect id="hzk7v"><em id="hzk7v"></em></delect></listing>

      laravel 事件/监听器实例代码

       更新时间2019年04月12日 10:28:25   作者haoyq   我要评论

      这篇文章主要介绍了laravel 事件/监听器实例代码文中通过示例代码介绍的非常详细对大家的学习或者工作具有一定的参考学习价值需要的朋友们下面随着小编来一起学习学习吧

      导语

      上一篇文章实现了记录用户访问设计上是有缺陷的代码紧耦合在中间件如果后续修改需求不仅记录 ip城市还需要记录数据到新的数据表或者需要进行其它统计那么不停的增加修改代码是不合理的这个时候可以使用 Laravel 的事件/监听器进行处理代码可查看 GitHub

      事件/监听器

      Laravel 事件提供了简单的观察者模式实现?#24066;?#20320;订阅和监听应用中的事件

      观察者模式有时也被称作发布/订阅模式该模式用于为对象实现发布/订阅功能一旦主体对象状态发生改变与之关联的观察者对象会收到通知并进行相应操作

      以上是事件/监听器观察者模式的简要说明结合这次的需求理解当触发用户访问事件它的观察者进行处理观察者可以是多个本例仅做入库操作

      创建事件/监听器

      在 app/Providers/EventServiceProvider.php 文件中添加事件/监听器如下

       /**
         * The event listener mappings for the application.
         *
         * @var array
         */
        protected $listen = [
          Registered::class => [
            SendEmailVerificationNotification::class,
          ],
          'App\Events\UserBrowse' => [
            'App\Listeners\CreateBrowseLog',
            // 其它监听器
          ],
        ];
      

      添加好之后执行 php artisan event:generate会自动创建对应的事件/监听器分别创建了 app/Events/UserBrowse.php 和 app/Listeners/CreateBrowseLog.php 两个文件

      实现代码

      把目光聚集到事件 app/Events/UserBrowse.php 文件这里需要接收数据以便后续处理代码如下

        public $ip_addr;
        public $request_url;
        public $city_name;
      
        /**
         * Create a new event instance.
         *
         * @return void
         */
        public function __construct($ip_addr, $request_url, $city_name)
        {
          $this->ip_addr = $ip_addr;
          $this->request_url = $request_url;
          $this->city_name = $city_name;
        }
      
      

      然后是监听器 app/Listeners/CreateBrowseLog.php这里要做的是将事件中接收到的数据进行入库操作代码如下

      /**
         * Handle the event.
         *
         * @param UserBrowse $event
         * @return void
         */
        public function handle(UserBrowse $event)
        {
          $log = new \App\Models\BrowseLog();
      
          $log->ip_addr = $event->ip_addr;
          $log->request_url = $event->request_url;
          $log->city_name = $event->city_name;
      
          $log->save();
        }
      
      

      分发事件

      最后就是分发事件修改 app/Http/Middleware/BrowseLog.php 中间件的代码修改后如下

      /**
         * Handle an incoming request.
         *
         * @param \Illuminate\Http\Request $request
         * @param \Closure $next
         * @return mixed
         */
        public function handle($request, Closure $next)
        {
          // 使用事件/监听器入库
          event(new UserBrowse($request->getClientIp(), $request->path(), get_city_by_ip(false, 'null')));
          
          return $next($request);
        }
      

      测试之后是没有问题的

      结语

      这次所做的修?#27169;?#24863;官上来看就是将入库操作从中间件转移到监听器中实际上的意义远不止于此例如同一个事件可以分发在不同的地方事件添加了需求只需要在添加一个监听器即可监听器中也可以使用队列等等

      以上就是本文的全部内容希望对大家的学习有所帮助也希望大家多多支持脚本之家

      您可能?#34892;?#36259;的文章:

      相关文章

      最新评论

      3dԻв

        1. <output id="hzk7v"><pre id="hzk7v"><address id="hzk7v"></address></pre></output>
          <output id="hzk7v"></output>
        2. <nav id="hzk7v"><i id="hzk7v"><em id="hzk7v"></em></i></nav>
        3. <listing id="hzk7v"><delect id="hzk7v"><em id="hzk7v"></em></delect></listing>

            1. <output id="hzk7v"><pre id="hzk7v"><address id="hzk7v"></address></pre></output>
              <output id="hzk7v"></output>
            2. <nav id="hzk7v"><i id="hzk7v"><em id="hzk7v"></em></i></nav>
            3. <listing id="hzk7v"><delect id="hzk7v"><em id="hzk7v"></em></delect></listing>