Подтвердить что ты не робот

Вызов другой функции в том же контроллере?

У меня есть этот контроллер, и function read($q) возвращает ошибку Call to undefined function sendRequest()

<?php

class InstagramController extends BaseController {

/*
|--------------------------------------------------------------------------
| Default Home Controller
|--------------------------------------------------------------------------
|
| You may wish to use controllers instead of, or in addition to, Closure
| based routes. That great! Here is an example controller method to
| get you started. To route to this controller, just add the route:
|
|   Route::get('/', '[email protected]');
|
*/

public function read($q)
{
    $client_id = 'ea7bee895ef34ed08eacad639f515897';

    $uri = 'https://api.instagram.com/v1/tags/'.$q.'/media/recent?client_id='.$client_id;
    return sendRequest($uri);
}

public function sendRequest($uri){
    $curl = curl_init($uri);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0);
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0);
    $response = curl_exec($curl);
    curl_close($curl);
    return $response;
}

}

Я предполагаю это, потому что я ссылаюсь на функцию неправильно, но я не могу найти никаких объяснений, как это сделать.

4b9b3361

Ответ 1

Try:

return $this->sendRequest($uri);

Так как PHP не является чистым языком Object-Orieneted, он интерпретирует sendRequest() как попытку вызвать глобально определенную функцию (например, как nl2br() например), но так как ваша функция является частью класса ('InstagramController '), вы должны использовать $this, чтобы указать интерпретатор в правильном направлении.

Ответ 2

Да. Проблема в неправильном обозначении. Использование:

$this->sendRequest($uri)

Вместо. Или же

self::staticMethod()

для статических методов. Также прочитайте это, чтобы получить представление об ООП - http://www.php.net/manual/en/language.oop5.basic.php