>백엔드 개발 >PHP 튜토리얼 >Laravel 프레임워크는 SQL 문을 기록하기 위해 리스너를 사용하는 기능을 구현합니다.

Laravel 프레임워크는 SQL 문을 기록하기 위해 리스너를 사용하는 기능을 구현합니다.

不言
不言원래의
2018-06-07 09:48:201911검색

이 글에서는 리스너를 이용하여 SQL 문을 기록하는 기능을 구현하기 위한 Laravel 프레임워크를 주로 소개하고, Laravel 프레임워크 리스너의 생성 및 도입과 리스너를 이용하여 SQL 문을 기록하는 관련 조작 기술을 예제 형식으로 분석합니다. 도움이 필요한 친구는 다음을 참고할 수 있습니다.

이 기사의 예는 Laravel 프레임워크가 리스너를 사용하여 SQL 문을 기록하는 기능을 구현하는 방법을 설명합니다. 참조용으로 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

리스너를 사용하여 SQL 문을 기록합니다

1. SQL 문을 모니터링하기 위한 이벤트 클래스가 정의되었습니다. 리스너 클래스를 직접 생성하세요.

# 监听sql
make:listener QueryListener --event=Illuminate\Database\Events\QueryExecuted

2. 리스너 클래스 코드

./app/Listeners/QueryListener.php

<?php
namespace App\Listeners;
use Illuminate\Database\Events\QueryExecuted;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use App\Http\Models\OperationLog;
class QueryListener
{
  /**
   * Create the event listener.
   *
   * @return void
   */
  public function __construct()
  {
    //
  }
  /**
   * Handle the event.
   *
   * @param QueryExecuted $event
   * @return void
   */
  public function handle(QueryExecuted $event)
  {
    $sql = str_replace("?", "&#39;%s&#39;", $event->sql);
    $log = vsprintf($sql, $event->bindings);
    # 此处$uid定义是依赖于中间件记录操作日志代码
    $uid = isset($_SERVER[&#39;admin_uid&#39;]) ? $_SERVER[&#39;admin_uid&#39;] : 0;
    if(&#39;select&#39; != substr($log , 0 , 6)){
      if(&#39;insert into `operationLog`&#39; != substr($log , 0 , 26)){
        $OperationLog = new OperationLog();
        $OperationLog->uid = $uid;
        $OperationLog->sql = $log;
        $OperationLog->input = &#39;&#39;;
        $OperationLog->save();
      }
    }
  }
}

3. 리스너 소개

./app/Providers/Event ServiceProvider.php

protected $listen = [
    ...
    \Illuminate\Database\Events\QueryExecuted::class => [
      &#39;App\Listeners\QueryListener&#39;
    ],
    ...
  ];

이 때 작업이 수행되면 SQL 로그가 기록됩니다.

관련 권장 사항:

Laravel5에서 퍼지 일치 및 다중 조건 쿼리 기능을 구현하는 방법

위 내용은 Laravel 프레임워크는 SQL 문을 기록하기 위해 리스너를 사용하는 기능을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.