当注入构造函数时,我似乎无法获得PHP-DI来正确解析与其配置的类的接口。在下面的代码中,使用容器获取\ Foo \ IDog返回一个Poodle类,但是当使用容器获取\ Foo \ Kennel(在构造函数中具有\ Foo \ IDog时,它不再识别它已配置为返回贵宾犬,并显示错误消息:
"Entry "\Foo\Kennel" cannot be resolved: Entry "Foo\IDog" cannot be resolved: the class is not instantiable"
这是概念证明:
<?php
namespace Foo;
require(__DIR__ . "/vendor/autoload.php");
interface IDog {
function bark();
}
class Poodle implements IDog {
public function bark() {
echo "woof!" . PHP_EOL;
}
}
class Kennel {
protected $dog;
public function __construct(\Foo\IDog $dog) {
$this->dog = $dog;
}
public function pokeDog() {
$this->dog->bark();
}
}
$containerBuilder = new \DI\ContainerBuilder();
$containerBuilder->addDefinitions([
"\Foo\IDog" => \DI\autowire("\Foo\Poodle")
]);
$container = $containerBuilder->build();
//Works:
$mydog = $container->get("\Foo\IDog");
$mydog->bark();
//Does not work:
$kennel = $container->get("\Foo\Kennel");
$kennel->pokeDog();
奇怪的是,如果我从其中删除所有命名空间(在这里没有命名空间:https://gist.github.com/brentk/51f58fafeee8029d7e8b1e838eca3d5b),它就可以正常工作。
知道我在做什么错吗?
答案 0 :(得分:2)
我认为这是因为您的类名在您的配置中无效:"\Foo\IDog"
无效,"Foo\IDog"
是有效的。
在代码\Foo\IDog
中也可以,但是在字符串中只有Foo\IDog
是有效的。
避免这种情况的安全方法是使用\Foo\IDog::class
。这样,PHP会告诉您该类不存在。