一文详解Laravel中怎么进行异常处理

一文详解Laravel中怎么进行异常处理

在本文中,我们将探讨 Laravel Web 框架中最重要和最少讨论的功能之一 – 异常处理。 Laravel 带有一个内置的异常处理程序,可以让您轻松地以友好的方式报告和呈现异常。

在文章的前半部分,我们将探讨异常处理程序提供的默认设置。 事实上,我们首先会通过默认的 Handler 类来理解 Laravel 是如何处理异常的。

在文章的后半部分,我们将继续介绍如何创建自定义异常处理程序,以便您可以捕获自定义异常。

基本配置

在开始研究异常处理类之前,让我们先来看看几个和异常相关且很重要的参数配置。

打开 config/app.php 文件,并仔细的看看下面的代码片段。

....../*|--------------------------------------------------------------------------| 应用的调试模式|--------------------------------------------------------------------------|| 当引用处于调试模式,将会显示错误产生式的详细堆栈信息| 如果禁用,则只显示一个简单的错误页面|*/'debug' => env('APP_DEBUG', false),......

从参数的名称可以猜到,如果设置为 TRUE,将有利于我们调试应用产生的错误。默认值由 .env 环境变量配置文件中的  APP_DEBUG 参数指定。

在开发环境下,建议你将它设置为 TRUE ,这样,通过清晰的错误堆栈信息,能很快的定位错误产生的原因并修复。 另外,当处于正式环境是,我们需要通过环境变量的配置项来关闭它,当错误产生式将只显示通用的提示页面。

除了将错误显示在页面上,Laravel 也允许你将错误记录到日志文件中。现在,让我们来看看日志相关的配置,打开 config/app.php 文件,并仔细的看看下面的代码片段。

......'log' => env('APP_LOG', 'single'),'log_level' => env('APP_LOG_LEVEL', 'debug'),......

Laravel 框架中,是使用 Monolog 库来记录日志的。你可以通过上面的配置项来配置 Monolog 库。

默认的日志文件保存路径为 storage/logs/laravel.log,通常情况下,你无需更改它。与此同时,你可以通过  APP_LOG_LEVEL 来指定需要被记录到日志文件的错误级别。

前面介绍了异常和日志的基本配置。

接下来,我们看看 Laravel 应用默认的异常处理类。打开 app/Exceptions/Handler.php 文件.

expectsJson()) {            return response()->json(['error' => 'Unauthenticated.'], 401);        }        return redirect()->guest(route('login'));    }}

上面的处理类主要包含2个功能:报告和显示所有的异常信息。

让我们仔细看一眼 report 方法。

/** * 报告或记录一个异常。 * * 这是一个将异常发送给 Sentry 和 Bugsnag 等机构的好时机。 * * @param  Exception  $exception * @return void */public function report(Exception $exception){    parent::report($exception);}

report 方法用于将错误记录到日志文件中。同时,关注一项重要的 dontReport 属性,它列出了所有不应该被记录到日志的异常类别。

接下来,我们介绍 render 方法。

/** * 将异常渲染至 HTTP 响应值中。 * * @param  IlluminateHttpRequest  $request * @param  Exception  $exception * @return IlluminateHttpResponse */public function render($request, Exception $exception){    return parent::render($request, $exception);}

如果说 report 方法是用于记录或报告错误,那么 render 方法是用于将错误渲染显示在屏幕上。事实上,当异常发生时,这个方法决定了哪些内容将被展示给用户。

render 方法也允许你针对不同类别的错误自定义响应值,这部分内容我们将在下一章学习。

最后, unauthenticated 方法处理了 AuthenticationException 异常,你能够在此决定当用户访问了一个未授权页面时所展示的内容。

文心大模型 文心大模型

百度飞桨-文心大模型 ERNIE 3.0 文本理解与创作

文心大模型 56 查看详情 文心大模型

自定义异常类

在这一节,我们将创建一个自定义异常类,用于处理 CustomException 类别的异常。创建自定义异常类背后的想法是更轻松地管理自定义异常同时显示自定义响应。

开始着手创建一个文件 app/Exceptions/CustomException.php ,内容如下所示。

view(                'errors.custom',                array(                    'exception' => $this                )        );    }}

重要的是需要注意 CustomException 类必须继承核心 Exception 类。为了演示用途,我们仅仅讨论了 render 方法,但显然你也能够自定义修改 report 方法。

正如你看到的,在样例中我们将用户重定向至 errors.custom 错误页面。通过这种方式,你能够为特定类型的异常实现自定义的错误页面。

当然,我们需要创建一个关联的视图文件 resources/views/errors/custom.blade.php

Exception details: {{ $exception->getMessage() }}

这是一个相当简单的视图文件,只显示一行错误消息,不过你也可以按照自己希望的方式设计这个视图。

我们也需要在 app/Exceptions/Handler.php 文件的 render 方法中进行一些修改,保证我们的自定义异常类能够被调用。让我们将 app/Exceptions/Handler.php 文件中的 render 方法替换为以下内容。

....../** * 将异常渲染至 HTTP 响应值中。 * * @param  IlluminateHttpRequest  $request * @param  Exception  $exception * @return IlluminateHttpResponse */public function render($request, Exception $exception){    if ($exception instanceof AppExceptionsCustomException)  {        return $exception->render($request);    }    return parent::render($request, $exception);}......

正如你所看到的,我们会在 render 方法中首先检查异常的类型。如果异常的类别是 AppExceptionsCustomException ,我们将调用这个类的 render 方法。

一切准备就绪。现在我们创建一个控制  app/Http/Controllers/ExceptionController.php  来测试自定义的异常类。

<?phpnamespace AppHttpControllers;use AppHttpControllersController;class ExceptionController extends Controller{    public function index()    {        // 出错了,你可以抛出自定义的异常 CustomException        throw new AppExceptionsCustomException('Something Went Wrong.');    }}

当然,你需要先在 routes/web.php 文件中添加相关的路由,就像下面一样。

// Exception routesRoute::get('exception/index', 'ExceptionController@index');

之后,你可以浏览 http://your-laravel-site.com/exception/ind… 地址来查看是否和预期的一样。一切正常的话,页面将显示我们前面配置 errors.custom 视图。

就这样,你就可以按自己方式来处理 Laravel 中的异常。
完!尽情享受 Laravel 带来的编码的乐趣吧!

总结

今天,我们认真学习了 Laravel 中的异常处理特性。在文章的开头,我们搜索了 Laravel 提供的一些基础配置,用于显示和报告异常。紧接着,我们简要介绍了默认的异常处理类。

在文章的后半部分,我们通过创建一个自定义异常处理类,演示如何在应用中处理自定义的异常。

对于那些刚刚起步学习 Laravel ,或者期待拓展阅读相关知识、网站、应用扩展的读者,这里有一系列您能够学习的内容,参见 Envato Market 。

期待听到任何形式的咨询或建议!

原文地址:https://code.tutsplus.com/tutorials/exception-handling-in-laravel–cms-30210译文地址:https://learnku.com/laravel/t/8783/exception-handling-in-laravel

【相关推荐:laravel视频教程】

以上就是一文详解Laravel中怎么进行异常处理的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/340858.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 18:10:00
下一篇 2025年11月5日 18:10:52

相关推荐

  • WordPress自定义表单JavaScript验证失效问题排查与解决

    本文旨在解决wordpress网站中使用oxygen builder和forminator构建自定义表单时,javascript验证脚本无法正常执行的问题。通过分析脚本加载时机和页面元素生成方式,提供两种解决方案:使用`jquery(window).load()`确保脚本在页面完全加载后执行,以及将…

    2025年12月21日
    000
  • 使用 PHP 和 AJAX/JSON 将数据传递给 JavaScript

    本文将演示如何使用 PHP 从数据库中检索数据,并将其通过 AJAX 请求以 JSON 格式传递给 JavaScript,最终在 HTML 页面上展示。重点解决 JSON 解析错误,并提供清晰的代码示例和步骤说明。 PHP 后端代码 首先,我们需要一个 PHP 函数来从数据库中检索数据,并将其编码为…

    2025年12月21日
    000
  • 使用 PHP 和 AJAX/JSON 将数据传递到 JavaScript 的教程

    本文档旨在指导开发者如何使用 PHP 从数据库中检索数据,并通过 AJAX 和 JSON 格式将其传递到 JavaScript 中,以便在网页上动态显示。我们将重点解决常见的 “Unexpected end of JSON input” 错误,并提供清晰的代码示例和步骤说明。…

    2025年12月21日 好文分享
    000
  • 使用 PHP 和 AJAX/JSON 将数据传递给 JavaScript 的教程

    本文档将详细介绍如何使用 PHP 从数据库中检索数据,并利用 AJAX 和 JSON 技术将其传递到 JavaScript 中,以便在网页上动态显示。我们将重点解决常见的 JSON 解析错误,并提供清晰的代码示例和最佳实践。 从 PHP 获取数据并编码为 JSON 首先,我们需要在 PHP 中编写代…

    2025年12月21日 好文分享
    000
  • PHP页面CDN资源集中管理实践:include函数详解

    本文探讨了在多个php页面中高效管理外部css和javascript cdn资源的方法。通过利用php的`include`函数,开发者可以将所有cdn链接集中到一个文件中,从而实现单一维护点、简化代码、避免重复,并持续享受cdn带来的性能与带宽优势。这是一种在不使用框架的情况下,提高项目可维护性的有…

    2025年12月21日
    000
  • js正则匹配html标签中的内容

    答案:使用正则提取HTML标签内容需谨慎,适用于简单场景。示例:const regex = /(2*)/ 可匹配 Hello 中的 Hello,但不推荐处理复杂或嵌套结构。> ↩ 要使用 JavaScript 正则匹配 HTML 标签中的内容,可以直接通过正则表达式捕获标签内的文本。但要注意:…

    2025年12月21日
    000
  • Drupal区块标题旁添加可点击链接的实现方法

    本教程详细介绍了如何在drupal区块标题旁添加可点击的“更多”链接。针对用户尝试使用css伪元素无法实现可点击链接的问题,文章提供了基于drupal 7和drupal 9/10+版本的模板覆盖解决方案。通过直接修改区块模板文件,开发者可以灵活地在标题旁插入自定义链接,确保功能性和可访问性,并提供了…

    2025年12月21日
    000
  • Drupal区块标题旁添加“更多”链接的实现教程

    本教程详细介绍了如何在drupal区块标题旁添加一个功能性的“更多”链接,以满足常见的内容导航需求。文章强调通过修改区块模板(drupal 9+使用twig,drupal 7使用php)是实现此功能的最佳实践,而非依赖css伪元素,因其无法创建可交互的链接。教程提供了详细的代码示例,并涵盖了模板查找…

    2025年12月21日
    000
  • JavaScript中从HTML隐藏输入获取列表长度的常见陷阱与解决方案

    本文旨在解决%ignore_a_1%开发者在尝试从html隐藏输入获取“列表”长度时遇到的常见问题。当将数组或类似列表的结构存储在html `value`属性中时,javascript会将其视为字符串而非数组。文章将深入探讨为何 `string.length` 会返回字符数而非元素数量,并提供通过字…

    2025年12月21日
    000
  • 手写一个符合Promises/A+规范的Promise_javascript技巧

    实现一个符合 Promises/A+ 规范的 Promise 需遵循状态不可变、异步执行、链式调用等规则,核心包括三种状态(pending、fulfilled、rejected)、then 方法返回新 Promise、resolvePromise 处理返回值、catch 和 finally 的语法糖…

    2025年12月21日
    000
  • 在Laravel Blade中正确使用Vite加载模块化JS与CSS资源

    本文旨在解决laravel应用中,特别是在使用模块化结构(如nwidart/laravel-module)时,通过vite加载前端js和css资源时遇到的404错误。核心内容是阐明`asset()`函数与vite指令的区别,并详细指导如何使用`@vite` blade指令及其正确路径配置,确保模块内…

    2025年12月21日
    000
  • Laravel模块化开发中Vite资源加载指南:解决Blade文件404错误

    本教程旨在解决在laravel模块化开发中,使用vite加载javascript和css资源时遇到的404错误。文章将深入探讨传统方法失败的原因,并详细介绍如何通过laravel提供的@vite blade指令,正确且高效地在blade模板中引入模块化vite资产,确保开发和生产环境下的资源路径解析…

    2025年12月21日
    000
  • Laravel Blade中Vite资产加载指南:解决模块化项目中的404错误

    本文旨在解决laravel blade模板中,尤其是在模块化项目中,使用vite加载javascript和css资源时遇到的404错误。我们将深入探讨传统方法失效的原因,并详细介绍如何通过laravel提供的`@vite` blade指令正确地集成和管理vite处理的资产,确保资源能够被成功编译和引…

    2025年12月21日
    000
  • Laravel模块中Vite资产加载指南

    本文详细介绍了在Laravel应用,特别是Nwidart模块中,如何正确使用Vite加载JavaScript和CSS资源。针对直接链接导致404错误的问题,教程阐明了Vite的工作原理,并提供了通过`@vite` Blade指令引用模块内资源的正确方法,确保开发流程顺畅,避免资源加载失败。 理解La…

    2025年12月21日
    000
  • JavaScript客户端密码强度动态验证实践指南

    本文深入探讨了javascript客户端密码校验中常见的逻辑错误,即密码强度验证未在提交时动态执行导致失效的问题。通过将正则表达式检测逻辑移至表单提交事件内部,确保密码强度能够实时更新并有效拦截不符合要求的密码,从而提升用户体验和应用的安全性。 在现代Web应用中,客户端密码验证是提升用户体验和减轻…

    2025年12月21日
    000
  • 优化JavaScript密码验证:实时检查与常见陷阱

    本教程探讨了javascript客户端密码验证中一个常见问题:正则表达式强度检查未在用户提交时实时执行。文章通过分析现有代码,指出`passwordstrength`变量初始化后未更新的缺陷,并提供了将密码强度检测逻辑集成到提交事件处理函数中的解决方案,确保每次提交都能进行全面验证,从而提升用户体验…

    2025年12月21日
    000
  • 解决JavaScript客户端密码强度验证失效问题:动态检查机制详解

    本文深入探讨了javascript客户端密码强度验证中常见的陷阱,特别是当验证逻辑未在用户交互时动态执行时可能导致的问题。我们将通过一个实际案例,演示如何将密码强度正则表达式检查集成到表单提交事件中,确保密码验证逻辑在每次用户尝试提交时都能正确评估当前输入,从而提升用户体验和安全性。 客户端密码验证…

    2025年12月21日
    000
  • 如何通过链接预选单选框:URL参数传递与PHP实现

    本教程旨在讲解如何通过URL参数传递,实现在新页面打开时预先选中特定的单选框。我们将使用HTML、PHP来实现这一功能,通过修改链接地址,将参数传递到目标页面,并利用PHP脚本读取参数,动态地设置单选框的选中状态。这对于需要根据不同入口预设选项的场景非常有用。 概述 在Web开发中,有时我们需要根据…

    2025年12月21日
    000
  • 通过链接预选单选框:PHP实现方法

    本文档介绍了如何通过URL链接,预先选中目标页面中的单选框。核心思路是利用URL参数传递单选框的选中值,并在目标页面通过PHP读取该参数,动态设置单选框的`checked`属性。本方法简单易懂,适用于需要在不同页面间传递单选框状态的场景。 方案概述 实现通过链接预选单选框的核心在于: 构建带有参数的…

    2025年12月21日
    000
  • 使用 JavaScript 获取当前用户的用户名

    本文旨在介绍如何在 JavaScript 中获取当前用户的用户名。由于 JavaScript 运行在客户端,而用户身份验证通常在服务器端进行,因此我们需要借助服务器端技术(如 PHP)将用户名传递给 JavaScript。本文将提供一种使用 PHP 的 `$_SESSION` 变量将用户名传递给 J…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信