拦截线上 sql 异常报错

背景:APP_DEBUG 模式无效,laravel 没有对线上的 sql 报错进行拦截,为了系统的安全、稳定,为了用户有更好的体验,还是需要对 sql 报错进行拦截的

1、在 App\Providers\AppServiceProviderboot

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’

拦截线上 sql 异常报错

use Illuminate\Database\QueryException;

public function boot()
{
  if (!env('APP_DEBUG')) {
     \API::error(function (QueryException $exception) {
           httpErrorNotFound($exception->getPrevious()->getMessage());
      });
    }
}
本作品采用《CC 协议》,转载必须注明作者和本文链接
萧风
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 2
panda-sir

:joy:这个是异常么 理论上来说拦截异常就行吧

4年前 评论
萧风 (楼主) 4年前
panda-sir

我的意思是这样

file

放在异常处理类中处理更规范点吧 :joy:

4年前 评论
萧风 (楼主) 4年前