拦截线上 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 协议》,转载必须注明作者和本文链接
萧风
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
讨论数量: 2
panda-sir

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

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

我的意思是这样

file

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

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

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