Laravel dd功能限制

vit*_*itr 8 php debugging laravel

我有一个320个数组的数组,而常规var_dump显示320个元素与所有嵌套元素,Laravel的dd帮助器截断索引147处的嵌套元素,所有其他元素被截断,没有选项来展开它们,请参阅下面的示例

  146 => array:17 [?
    "total_unconfirmed_subscribers" => 0
    "total_subscribers_subscribed_yesterday" => 0
    "unique_list_id" => "24324"
    "http_etag" => ""fbb6febfca8af5541541ea960aaedb""
    "web_form_split_tests_collection_link" => "https://api.com/1.0/"
    "subscribers_collection_link" => "https://api.com/1.0/"
    "total_subscribers_subscribed_today" => 0
    "id" => 23432
    "total_subscribed_subscribers" => 0
    "total_unsubscribed_subscribers" => 0
    "campaigns_collection_link" => "https://api.com/1.0/"
    "custom_fields_collection_link" => "https://api.com/1.0/accounts"
    "self_link" => "https://api.com/1.0/accounts"
    "total_subscribers" => 0
    "resource_type_link" => "https://api.com/1.0/#list"
    "web_forms_collection_link" => "https://api.com/"
    "name" => "dccode"
  ]
  147 => array:17 [?
    "total_unconfirmed_subscribers" => 0
     …16
  ]
  148 => array:17 [ …17]
  149 => array:17 [ …17]
Run Code Online (Sandbox Code Playgroud)

为什么它限制为147个完整记录以及如何增加限制?相关主题是Laravels的DD辅助函数是否正常工作?实际上没有解释限制.

这是非常一致的行为,我已经使用Laravel 5.2和php7进行了测试

  • Linux(Laravel Forge,DO droplet,Ubuntu)
  • Mac(Laravel代客)
  • Windows(valet4windows)

元素#147的所有地方都完全相同.使用CLI php artisan tinker输出相同的剪切

...
"name" => "dccode"   ]   147 => array:17 [
"total_unconfirmed_subscribers" => 0
 16   ]   148 => array:17 [ 17]
...
Run Code Online (Sandbox Code Playgroud)

sle*_*ess 15

在5.0版之前,laravel的dd()功能如下:

function dd()
{
    array_map(function($x) { var_dump($x); }, func_get_args()); die;
}
Run Code Online (Sandbox Code Playgroud)

从5.0开始它看起来像这样:

function dd()
{
    array_map(function ($x) {
        (new Dumper)->dump($x);
    }, func_get_args());

    die(1);
}
Run Code Online (Sandbox Code Playgroud)

Dumper使用的symfony的VarCloner被延长AbstractCloner.此类的$maxItems属性设置为2500.请参阅:https://github.com/symfony/var-dumper/blob/master/Cloner/AbstractCloner.php#L125

每个阵列有17个项目.将它乘以147得到2499.这就是为什么你的第147项的数组在它的第一项之后被截断的原因.

如果你想增加它,你需要覆盖laravel的Dumper类(https://github.com/laravel/framework/blob/5.2/src/Illuminate/Support/Debug/Dumper.php):

public function dump($value)
{
    if (class_exists(CliDumper::class)) {
        $dumper = 'cli' === PHP_SAPI ? new CliDumper : new HtmlDumper;

        $cloner = new VarCloner();
        $cloner->setMaxItems(5000);
        $dumper->dump($cloner->cloneVar($value));
    } else {
        var_dump($value);
    }
}
Run Code Online (Sandbox Code Playgroud)


Luc*_*ins 9

我的建议是您在VarDumper组件中添加一个处理程序

在您的AppServiceProvider.php中:

class声明前)

use Symfony\Component\VarDumper\VarDumper;
use Symfony\Component\VarDumper\Cloner\VarCloner;
use Symfony\Component\VarDumper\Dumper\CliDumper;
use Symfony\Component\VarDumper\Dumper\HtmlDumper;
Run Code Online (Sandbox Code Playgroud)

(内部boot()方法)

VarDumper::setHandler(function ($var) {
    $cloner = new VarCloner();
    $cloner->setMaxItems(-1); // Specifying -1 removes the limit
    $dumper = 'cli' === PHP_SAPI ? new CliDumper() : new HtmlDumper();

    $dumper->dump($cloner->cloneVar($var));
});
Run Code Online (Sandbox Code Playgroud)

根据Symfony 的 VarDumper 组件文档

setMaxItems()配置将克隆超过最小嵌套深度的最大项目数。使用广度优先算法对项目进行计数,以便较低级别的项目比深度嵌套的项目具有更高的优先级。指定 -1 将删除限制。

在文档中,您可以看到用于自定义 Cloners、Dumpers 和 Casters 组件的其他方法。


小智 5

我对您的建议是在 bootstrap 文件夹中创建一个自定义帮助文件

1) 按照下面的回答为你的 Laravel 应用程序创建一个自定义的辅助函数,如果它太复杂,你可以跳过下面的步骤,使用我在步骤 2 中的函数作为任何普通函数,只需调用它 >> https:// stackoverflow.com/a/28290359/10539212

2)我想给这个人一些功劳,我按照他的指南来创建我自己的 ddd 函数 >> https://tighten.co/blog/a-better-dd-for-your-tdd

use Illuminate\Support\Debug\HtmlDumper;
use Symfony\Component\VarDumper\Cloner\VarCloner;
use Symfony\Component\VarDumper\Dumper\CliDumper;

function ddd()
{
    $args = func_get_args();
    $defaultStringLength = -1;
    $defaultItemNumber = -1;
    $defaultDepth = -1;

    foreach ($args as $variable) {
        $dumper = 'cli' === PHP_SAPI ? new CliDumper() : new HtmlDumper();

        $cloner = new VarCloner();
        $cloner->setMaxString($defaultStringLength);
        $cloner->setMaxItems($defaultItemNumber);

        $dumper->dump($cloner->cloneVar($variable)->withMaxDepth($defaultDepth));
    }

    die(1);
}
Run Code Online (Sandbox Code Playgroud)

-1 = 无限制(以这种方式易于自定义)

所以,现在当你使用这个 ddd 函数时,你可以得到普通 dd 函数的完整输出。我认为这种方法比覆盖任何现有功能要好。但要小心,因为现在任何深度的变量都将被完整显示,你可能会遇到更长的加载时间。希望能帮助到你。