拦截线上 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 协议》,转载必须注明作者和本文链接
萧风
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 2
panda-sir

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

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

我的意思是这样

file

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

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

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!