codecamp

Laravel 8 Reportable & Renderable 异常

除了在异常处理器的 reportrender 方法中检查异常类型外,您也可以直接在您的自定义异常中定义 reportrender 方法。当定义了这些方法时,它们将被框架自动调用:

<?php

namespace App\Exceptions;

use Exception;

class RenderException extends Exception
{
    /**
     * 报告异常
     *
     * @return void
     */
    public function report()
    {
        //
    }

    /**
     * 渲染异常为 HTTP 响应
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function render($request)
    {
        return response(...);
    }
}

如果您的异常包含了仅在满足某些条件时才报告的自定义报告逻辑,您可能需要指示 Laravel 使用默认的异常处理配置去报告它。您可以在异常的 report 方法中返回 false 以实现之:

/**
 * 报告异常
 *
 * @return bool|void
 */
public function report()
{
    // 判断异常是否需要自定义报告...

    return false;
} 

技巧:您可以通过类型提示传递任意的依赖到 report 方法中,它们将被 Laravel 的 服务容器 自动注入到方法中。


Laravel 8 渲染异常
Laravel 8 HTTP 异常
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Laravel 8 入门指南

Laravel 8 基础功能

Laravel 8 前端开发

Laravel 8 安全相关

Laravel 8 综合话题

数据库

Eloquent ORM

测试相关

官方拓展包

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }