PHP: использование file_get_contents() в классе __constructor является плохой практикой?

У меня есть класс, который делает экономический календарь из строки json. Единственная проблема в том, что я не знаю, следует ли мне использовать file_get_contents() (для получения данных из API) внутри моего класса __constructor() или я должен просто передать строку json в __constructor из моего блока try{...}catch{...}?

Какая практика лучше и почему?

Вот мой класс (ЭкономическийКалендарь.php) до сих пор:

class EconomicCalendar{

    private $_data,
            $_calendar = [];

    public function __construct($url){
        $this->_data = json_decode(file_get_contents($url));
    }

    private function make_economic_calendar(){
        foreach($this->_data->events as $e){
            $arr[$e->date][] = [
                'title' => $e->title,
                'date' => $e->date
            ];
        } 

        if (is_array($arr) && count($arr) >= 1){
            return (object)$arr;
        } else{
            throw new Exception('EC was not created');
        }
    }

    public function get_calendar(){
        $this->_calendar = $this->make_economic_calendar();
        return $this->_calendar;
    }

}

Вот код (ec.php), который выводит календарь:

spl_autoload_register(function($class){
    require_once dirname(__FILE__) . DIRECTORY_SEPARATOR . $class . '.php';
});

try {
    $c = new EconomicCalendar('https://api.example.com/ec?token = {MY_TOKEN}');
    $economic_calendar = $c->get_e_list(); 
} catch (Exception $e) {
    exit($e->getMessage());
}

Спасибо!

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
3
0
1 100
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Почти всегда лучше сделать операцию ввода-вывода как можно позже (или как можно меньше). Поэтому я рекомендую вам использовать «именованный конструктор», если вы хотите инициализировать данные

class EconomicCalendar {

    ...

    public function __construct($data){
        $this->_data = $data;
    }

    ...

    public static function fromUrl($url){
        return new self(json_decode(file_get_contents($url)));
    }

}

И использование:

$instance = EconomicCalendar::fromUrl('https://api.example.com/ec?token = {MY_TOKEN}');

Перемещение ввода-вывода и декодирования в выделенную функцию ближе к принципу единой ответственности (IO в статике, логика в экземпляре класса).

Привет, @PeliCan, но разве я не должен переместить file_get_contents() за пределы этого класса и просто отправить строку json через __constructor? Разве вызовы API внутри класса не являются плохой практикой?

emma 16.06.2019 19:48

Перемещая его в статическую область видимости, извлекает его "из" класса (помещается только в тот же файл). Вы можете извлечь конструирующий объект еще дальше в другой класс, но я думаю, что это не обязательно.

PeliCan 16.06.2019 20:10

Другие вопросы по теме