我想我做得对,因为我可以通过开发模式否决文件,但我确定要问。为通过composer安装的服务存储API密钥的正确位置是什么。现在我将密钥存储在local.php内的autoload目录中,并通过服务定位器接收它们。
例如
$config = $this->serviceLocator->get('Config');
var_dump($config['service_name_api']); // Returns api key
这是正确的方式,还是应该使用其他方式来访问这些属性?
答案 0 :(得分:1)
这看起来像我要做的,虽然你需要提供一个默认值(在你的模块配置中),这在api键上下文中是不可能的,或者在你的工厂中抛出一个正确的异常,因为你没有&# 39;想要在几个月内拥有undefined index service_name_api
:)
有些人还喜欢拥有配置对象,并且只为此对象设置工厂(它有助于管理默认值而不会崩溃)。我个人倾向于发现它有点太多了,除非你的密钥在很多地方被重用,在这种情况下你会重复工厂测试。
所以不要将以下内容添加到每个使用它的工厂
if (!isset($config['service_name_api']) || !is_string($config['service_name_api'])) {
throw new \Exception('No "service_name_api" found in the configuration');
}
你可以有一个简单的对象
final class ServiceNameApiOption
{
private $key;
public function __construct(string $apiKey)
{
$this->key = $apiKey;
}
public function getKey() : string
{
return $this->key;
}
}
然后是一家工厂:
final class ServiceNameApiOptionFactory
{
public function __invoke(ContainerInterface $container)
{
$config = $container->get('Config');
if (!isset($config['service_name_api']) || !is_string($config['service_name_api'])) {
throw new \Exception('No "service_name_api" found in the configuration');
}
return new ServiceNameApiOption($config['service_name_api']);
}
}
答案 1 :(得分:1)
最佳位置是:
config/autoload/{config file name you want}.local.php
我建议结构:
[
'keystore' => [
'api' => [
// keys array
]
]
]
重复我建议上面的结构,你可以创建自己的结构,但无论如何添加
config/autoload/{config file name you want}.local.php.dist
包含示例数据的文件。