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进行了测试
元素#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)
我的建议是您在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)
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 函数的完整输出。我认为这种方法比覆盖任何现有功能要好。但要小心,因为现在任何深度的变量都将被完整显示,你可能会遇到更长的加载时间。希望能帮助到你。