有没有办法使用Symfony 4修复日期错误?

时间:2019-03-26 13:46:20

标签: date command symfony4 php-7.2

我正在使用PHP 7.2.11和Symfony 4.2.3作为后端开发人员进行项目开发

我的目标是通过交互式地图上的API获取的数据来展示事件(音乐会,节日等)。

这是我得到的结果:

https://imgur.com/HmpBK5B.png

要从API导入数据,请使用 for循环(从1到7(对应于天数)),然后在今天的日期后加上天数。

该日期将用作获取从今天到接下来的7天发生的事件的参数。

问题是:运行自定义symfony命令时出现以下错误 php bin /控制台导入:mapado

  

2019-03-26T12:08:34 + 01:00 [错误]运行命令“ import:mapado”时引发错误。消息:“通知:未定义的索引:地址”

错误是由于日期不存在,然后引用的地址不存在。

我试图在第一个for循环中更改参数,将天数更改为8或6,但是它没有更改输出错误。

我将自定义日期参数(从我的循环中)从API url更改为默认参数,并且一切都在默认情况下正常工作(但它仅获取接下来3天的事件)。

这是我使用的参数:

https://imgur.com/tx1OyrM.png

发件人:https://api.mapado.net/v2/docs#operation/getActivityCollection

API元素的外观如下:

https://imgur.com/l1nTOCC.png

这是我编写的代码:

protected function execute(InputInterface $input, OutputInterface $output) {
        for ($jour = 0; $jour <= 7; $jour++) {
           // problem is here
            $futureDay = date('Y-m-d', strtotime('+'.$jour.' days'));

            $curl = curl_init();

            curl_setopt_array($curl, array(
                CURLOPT_URL => "https://api.mapado.net/v2/activities?fields=@id,title,shortDate,nextDate,activityType,locale,description,address&itemsPerPage=1000&when=".$futureDay."&periodOfDay=evening",
                CURLOPT_RETURNTRANSFER => true,
                CURLOPT_ENCODING => "",
                CURLOPT_MAXREDIRS => 10,
                CURLOPT_TIMEOUT => 30,
                CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
                CURLOPT_CUSTOMREQUEST => "GET",
                CURLOPT_HTTPHEADER => array(
                    "Authorization: Bearer MTMwZWJiODFiZjA4YTcyOGY2ZmMzMGYwOTQyYWM2NDZjODVlNDg1MzU0MzE3M2I4MTdiMDQyZjU5MDVkZjFjZA",
                    "Cache-Control: no-cache",
                    "Conent-Type: application/json",
                    "Content-Type: application/x-www-form-urlencoded",
                    "Postman-Token: 55672a19-0ffc-4fe6-a866-3e15c3df9dae"
                ),
            ));

            $response = curl_exec($curl);
            $err = curl_error($curl);

            $mapado_events = json_decode($response, JSON_PRETTY_PRINT);

            for ($i = 0; $i < count($mapado_events['hydra:member']); $i++) {

                if ($mapado_events['hydra:member'][$i]['locale'] == 'fr') {

                    $mapado_id = $mapado_events['hydra:member'][$i]['@id'];
                    $mapado_date = \date('Y-m-d', strtotime($mapado_events['hydra:member'][$i]['nextDate']));

                    $result = $this->getContainer()
                        ->get('doctrine')
                        ->getRepository(MapadoIDs::class)
                        ->findOneBy(['mapado_id' => $mapado_id]);

                    if ($result == null) {
                        echo 'event existe pas, ajout en bdd'.PHP_EOL;
                        $MapadoIDs = new MapadoIDs();
                        $MapadoIDs->setMapadoId($mapado_id);
                        $this->em->persist($MapadoIDs);

                        $mapado = json_decode($response, JSON_PRETTY_PRINT);

                        $event = new Event();

                        $event->setLongitude($mapado['hydra:member'][$i]['address']['longitude']);
                        $event->setLatitude($mapado['hydra:member'][$i]['address']['latitude']);
                        $event->setTitle($mapado['hydra:member'][$i]['title']);
                        $event->setDate($mapado_date);
                        $event->setFormattedAddress($mapado['hydra:member'][$i]['address']['formattedAddress']);
                        $event->setCity($mapado['hydra:member'][$i]['address']['city']);
                        $event->setLocale($mapado['hydra:member'][$i]['locale']);
                        $event->setActivityType($mapado['hydra:member'][$i]['activityType']);
                        $event->setDescription($mapado['hydra:member'][$i]['description']);

                        $this->em->persist($event);                     
                    }
                }
            }
        }

        $this->em->flush();

        curl_close($curl);

        if ($err) {
            echo "cURL Error #: " . $err;
        } else {
            echo $response;
        }
    }
}

为了提高可读性:

https://pastebin.com/CTu5gb8t

预期结果是控制台中的json输出。 实际结果是抛出错误,阻止我将结果插入数据库。

您能告诉我是否缺少可能导致此错误的内容吗?

这是篇冗长而详细的文章,以便您可以更好地理解我的问题。

1 个答案:

答案 0 :(得分:0)

我解决了我的问题,这不是约会问题。

问题在于 itemsPerPage 查询参数请求太多数据,然后引发错误。

我将其设置为400,一切正常。