拦截线上 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 协议》,转载必须注明作者和本文链接
推荐文章: