拦截线上 sql 异常报错
背景:APP_DEBUG模式无效,laravel 没有对线上的 sql 报错进行拦截,为了系统的安全、稳定,为了用户有更好的体验,还是需要对 sql 报错进行拦截的
1、在 App\Providers\AppServiceProvider 的 boot
use Illuminate\Database\QueryException;
public function boot()
{
if (!env('APP_DEBUG')) {
\API::error(function (QueryException $exception) {
httpErrorNotFound("亲,服务器异常");
});
}
}
获取主要的报错信息,不显示详情里面的 sql 报错信息如下:
Column not found: 1054 Unknown column ‘asdasd’ in ‘where clause’

use Illuminate\Database\QueryException;
public function boot()
{
if (!env('APP_DEBUG')) {
\API::error(function (QueryException $exception) {
httpErrorNotFound($exception->getPrevious()->getMessage());
});
}
}
本作品采用《CC 协议》,转载必须注明作者和本文链接
关于 LearnKu
:joy:这个是异常么 理论上来说拦截异常就行吧
我的意思是这样
放在异常处理类中处理更规范点吧 :joy: