hpolthof/sneaker

当Laravel应用程序的服务器上发生异常时,一种方便的方式发送带有堆栈跟踪的电子邮件。

v5.1.0 2020-04-30 20:25 UTC

README

当Laravel应用程序的服务器上发生异常时,一种方便的方式发送带有堆栈跟踪的电子邮件。

sneaker example image

安装

通过Composer安装

对于Laravel <= 5.2,请使用v1分支

$ composer require squareboat/sneaker

配置Laravel

如果您使用的是 laravel 5.5 或更高版本,请跳过此步骤。

如果您使用laravel 5.3或5.4,只需将服务提供者添加到您的项目config/app.php文件中

服务提供者

SquareBoat\Sneaker\SneakerServiceProvider::class,

添加Sneaker的异常捕获

将异常捕获添加到app/Exceptions/Handler.php

public function report(Exception $exception)
{
    app('sneaker')->captureException($exception);

    parent::report($exception);
}

配置文件

使用此命令创建Sneaker配置文件

$ php artisan vendor:publish --provider="SquareBoat\Sneaker\SneakerServiceProvider"

配置文件将发布在config/sneaker.php

以下是Sneaker使用的配置属性。

silent

默认情况下,该软件包带有 'silent' => true, 配置,因为您可能不希望在开发环境中启用错误邮件。特别是如果您已将 'debug' => true, 设置。

'silent' => env('SNEAKER_SILENT', true),

要发送异常发生时的电子邮件,请在您的.env文件中设置 SNEAKER_SILENT=false

capture

它包含应捕获的异常类型的列表。您可以在此处添加您想要发送错误电子邮件的异常。

默认情况下,该软件包已包含 Symfony\Component\Debug\Exception\FatalErrorException::class

'capture' => [
    Symfony\Component\Debug\Exception\FatalErrorException::class,
],

您还可以在 $capture 数组中使用 '*',这将捕获所有异常。

'capture' => [
    '*'
],

要使用此功能,请在app/Exceptions/Handler.php中添加以下代码

public function report(Exception $exception)
{
    if ($this->shouldReport($exception)) {
        app('sneaker')->captureException($exception);
    }

    parent::report($exception);
}

这是错误电子邮件的收件人列表。

'to' => [
    // 'hello@example.com',
],

ignored_bots

这是我们不发送错误电子邮件的机器人列表。

'ignored_bots' => [
    'googlebot',        // Googlebot
    'bingbot',          // Microsoft Bingbot
    'slurp',            // Yahoo! Slurp
    'ia_archiver',      // Alexa
],

自定义

如果您需要自定义电子邮件的主题和正文,请运行以下命令

$ php artisan vendor:publish --provider="SquareBoat\Sneaker\SneakerServiceProvider"

注意 - 如果您已运行此命令,请勿再次运行。

现在电子邮件的主题和正文视图位于resources/views/vendor/sneaker目录中。

我们已经传递了抛出的异常对象 $exception 到视图中,您可以使用它来定制视图以适应您的需求。

Sneak

测试您的集成

要验证Sneaker配置正确且我们的集成正常工作,请使用sneaker:sneak Artisan命令

$ php artisan sneaker:sneak

将抛出并捕获 SquareBoat\Sneaker\Exceptions\DummyException 类。捕获的异常将立即出现在您配置的电子邮件中。

安全

如果您发现任何与安全相关的问题,请通过电子邮件akaamitgupta@gmail.com联系,而不是使用问题跟踪器。

致谢

关于SquareBoat

SquareBoat 是一家位于印度古尔冈的初创公司,专注于产品开发。您可以在GitHub上找到我们所有开源项目的概述 在此处

许可证

MIT许可证。有关更多信息,请参阅许可证文件。版权所有 © 2016 SquareBoat