Curl возвращает нулевой ответ при запуске из кустарной команды для задания cron - PullRequest
0 голосов
/ 10 мая 2019

Попытка запустить API, который даст мне обновленные значения температуры и влажности, но функция скручивания не работает, поскольку она дает NULL-ответ и выдает ошибку. запустить из терминала, чтобы проверить его

код:

        class updateTempHumHourly extends Command
    {
        /**
         * The name and signature of the console command.
         *
         * @var string
         */
        protected $signature = 'update:temphum';

        /**
         * The console command description.
         *
         * @var string
         */
        protected $description = 'Update temperature and humidity readings hourly';

        /**
         * Create a new command instance.
         *
         * @return void
         */
        public function __construct()
        {
            parent::__construct();
        }

        /**
         * Execute the console command.
         *
         * @return mixed
         */
        public function handle()
        {
            $options = array(
                'cluster' => 'ap2',
                'useTLS' => true
            );

            $pusher = new \Pusher\Pusher(
                'osdifnerwion4iownfowinf',
                'dofhewofhewofnowenfid',
                '7asdkland',
                $options
            );

            $thinkers = t::where('user_id', '!=' , NULL)->where('thinker_status',1)->get();

            foreach($thinkers as $t)
            {

                $temp = [
                    'action'=>'list_slave',
                    'mac'=> $t->thinker_MAC,
                    'type' => 'all',
                    'appkey' => 'nope'
                ];

                json_encode($temp);

                $response = Curl::to('http://103.31.82.46/open/open.php')
                ->withContentType('application/json')
                ->withData($temp)
                ->asJson(true)
                ->withHeader('Postman-Token: d5988618-676e-430c-808e-7e2f6cec88fc')
                ->withHeader('cache-control: no-cache')
                ->post();

                foreach($response['slaves'] as $s)
                {
                    if(array_key_exists("temp",$s) && array_key_exists("hum",$s))
                    {
                        $slave = sd::where("connected_thinker_MAC",$response['mac'])->where("device_id",$s['slave_id'])->first();
                        $slave->temperature = $s['temp'];
                        $slave->humidity = $s['hum'];
                        $slave->save();

                        $array = [];
                        $array['temperature'] = $s['temp'];
                        $array['humidity'] = $s['hum'];
                        $array['id'] = $s['slave_id'];

                        $pusher->trigger($t->user_id."-channel","s-event",$array);

                        \App\helper\log::instance()->tempHumLog($s);
                    }
                }
            }
        }
    }

цикл foreach выдает ошибку, что $ response равен нулю. функция curl не работает, но работает нормально. Помогите. мне нужно запускать эту задачу каждый час, чтобы получить среднюю температуру и влажность.

1 Ответ

0 голосов
/ 10 мая 2019

Поскольку вы сказали, что ваш код где-то работает, это означает, что что-то не так с вашим сервером, а не с самим кодом, вероятно (поскольку это проблема CURL).

Внутри вашего файла php.ini есть этострока: extension=php_curl.dll для включения скручивания.Раскомментируйте на своем сервере, что у вас есть кроны, чтобы заставить работать локон.Это должно решить вашу проблему.

Тестирование локально API, который вы предоставляете нам, возвращает 500, но если вы скажете, что это работает для вас, я предполагаю, что это только пример, и проблема в самом CURL.

...