이 글에서는 리스너를 이용하여 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("?", "'%s'", $event->sql); $log = vsprintf($sql, $event->bindings); # 此处$uid定义是依赖于中间件记录操作日志代码 $uid = isset($_SERVER['admin_uid']) ? $_SERVER['admin_uid'] : 0; if('select' != substr($log , 0 , 6)){ if('insert into `operationLog`' != substr($log , 0 , 26)){ $OperationLog = new OperationLog(); $OperationLog->uid = $uid; $OperationLog->sql = $log; $OperationLog->input = ''; $OperationLog->save(); } } } }
3. 리스너 소개
./app/Providers/Event ServiceProvider.php
protected $listen = [ ... \Illuminate\Database\Events\QueryExecuted::class => [ 'App\Listeners\QueryListener' ], ... ];
이 때 작업이 수행되면 SQL 로그가 기록됩니다.
관련 권장 사항:
Laravel5에서 퍼지 일치 및 다중 조건 쿼리 기능을 구현하는 방법
위 내용은 Laravel 프레임워크는 SQL 문을 기록하기 위해 리스너를 사용하는 기능을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!