php监听sql,laravel监听sql并生成日志,php artisan make:listener

项目根目录下执行:

php artisan make:listener SqlListener -e=QueryExecuted

会在App\Listener\下生成一个SqlListener文件,修改代码:

namespace App\Listeners;

use Illuminate\Database\Events\QueryExecuted;

use Illuminate\Queue\InteractsWithQueue;

use Illuminate\Contracts\Queue\ShouldQueue;

class SqlListener

{

/**

* 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);

$log .= "\r\n-----------------------------------------------";

$log = $log . "\r\n";

$filePath =storage_path('logs/sql.log');

file_put_contents($filePath, $log, FILE_APPEND);

}

}

然后在App/Provider/EventServiceProvider.php中加入:

namespace App\Providers;

use Illuminate\Support\Facades\Event;

use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;

class EventServiceProvider extends ServiceProvider

{

/**

* The event listener mappings for the application.

*

* @var array

*/

protected $listen = [

'App\Events\SomeEvent' => [

'App\Listeners\EventListener',

],

'Illuminate\Database\Events\QueryExecuted' => [

'App\Listeners\SqlListener'

]

];

/**

* Register any events for your application.

*

* @return void

*/

public function boot()

{

parent::boot();

//

}

}

给sql.log写入权限,执行相应程序会自动记录sql,也可以用tailf跟踪,不过要注意安全,这个放网上可能会暴露数据库结构

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值