ZF3正确放置你的api键的地方

时间:2017-01-19 12:07:21

标签: php config zend-framework3 service-locator

我想我做得对,因为我可以通过开发模式否决文件,但我确定要问。为通过composer安装的服务存储API密钥的正确位置是什么。现在我将密钥存储在local.php内的autoload目录中,并通过服务定位器接收它们。

例如

$config  = $this->serviceLocator->get('Config'); 
var_dump($config['service_name_api']); // Returns api key

这是正确的方式,还是应该使用其他方式来访问这些属性?

2 个答案:

答案 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

包含示例数据的文件。