Как создать новую инъекционную службу в Phalcon

#php #dependency-injection #phalcon

#php #внедрение зависимостей #phalcon

Вопрос:

Я пытаюсь создать базовый «JSON getter» для моего веб-приложения на основе Phalcon, что-то вроде этого:

 function getJson($url, $assoc=false)
{
$curl = curl_init($url);
$json = curl_exec($curl);
curl_close($curl);
return json_decode($json, $assoc);
}
  

И, конечно, я хотел бы сделать этот материал доступным по всему миру, возможно, в виде инъекционной службы. Какой может быть лучший способ сделать это? Должен ли я реализовать Phalcon DI Injectable? И затем, как я могу включить новый класс и передать его в DI?

Спасибо!

Комментарии:

1. Возможно, вы захотите взглянуть на черты. Черта также может быть хорошим решением вашей проблемы.

Ответ №1:

Вы могли бы расширить PhalconDIInjectable , но не обязательно. Служба может быть представлена любым классом. Документы довольно хорошо объясняют, как работать с внедрением зависимостей в целом и, в частности, с Phalcon.

 class JsonService 
{
    public function getJson($url, $assoc=false)
    {
        $curl = curl_init($url);
        $json = curl_exec($curl);
        curl_close($curl);
        return json_decode($json, $assoc);
    }
}

$di = new PhalconDI();

//Register a "db" service in the container
$di->setShared('db', function() {
    return new Connection(array(
        "host" => "localhost",
        "username" => "root",
        "password" => "secret",
        "dbname" => "invo"
    ));
});

//Register a "filter" service in the container
$di->setShared('filter', function() {
    return new Filter();
});

// Your json service...
$di->setShared('jsonService', function() {
    return new JsonService();
});

// Then later in the app...
DI::getDefault()->getShared('jsonService')->getJson(…);

// Or if the class where you're accessing the DI extends `PhalconDIInjectable`
$this->di->getShared('jsonService')->getJson(…);
  

Просто обратите внимание на get / set vs getShared . / setShared , есть службы, которые могут вызвать проблемы, если они создаются несколько раз снова и снова (не совместно используемые), например, занимают много ресурсов при создании экземпляра. Настройка службы как общей гарантирует, что она создается только один раз, а экземпляр используется повторно.