Проблема с обновлением Google Sheet только в первый раз - PullRequest
0 голосов
/ 06 ноября 2018

У меня проблема с обновлением Google Sheet данных. Для обновления данных я использую эту библиотеку, и она работает правильно, если вы вызываете прямой файл и работаете в локальной среде

Но проблема в том, что при запуске с сервера для обновления данных он выдает

500 внутренняя ошибка

и если я обновлю страницу, она будет работать правильно.

В принципе, это не работает в первый раз.

Согласно моему файлу error_log ошибка была

Предупреждение: htmlspecialchars () ожидает, что параметр 1 будет строкой

    <?php
require 'vendor/autoload.php';
use Google\Spreadsheet\DefaultServiceRequest;
use Google\Spreadsheet\ServiceRequestFactory;

//error_reporting(E_ALL);
//ini_set('display_errors', 'On');

class APIClass {
    function __construct($token){

        $serviceRequest = new DefaultServiceRequest($token);
        ServiceRequestFactory::setInstance($serviceRequest);
    }
    function updateNow($sku,$quantity){

        $this->updateNow($sku,$quantity);
        $spreadsheetService = new Google\Spreadsheet\SpreadsheetService();
        $spreadsheetFeed = $spreadsheetService->getSpreadsheetFeed();

        $spreadsheet = $spreadsheetFeed->getByTitle('product');
        $worksheetFeed = $spreadsheet->getWorksheetFeed();
        $worksheet = $worksheetFeed->getByTitle('Sheet2');
        $listFeed = $worksheet->getListFeed();

        $Entries = $listFeed->getEntries();


        $i = 0;
        $update = false;
        foreach ($listFeed->getEntries() as $entry) {
            $values[$i] = $entry->getValues();
            $i++;
        }

        for($k=0;$k<=$i;$k++){
            for($j=1;$j<=16;$j++){
                if($values[$k]['sku'] == $sku){
                    $listEntry = $Entries[$k];
                    $values['quantity'] = $quantity;
                    $listEntry->update($values);
                    $update = true;
                }
            }
        }
    }
}
function getClient()
    {
        $client = new Google_Client();
        $client->setApplicationName('Google Sheets API PHP Quickstart');
        $client->setScopes(Google_Service_Sheets::SPREADSHEETS);
        $client->setAuthConfig('credentials.json');
        $client->setAccessType('offline');
        $client->setPrompt('select_account consent');

        // Load previously authorized token from a file, if it exists.
        $tokenPath = 'token.json';
        if (file_exists($tokenPath)) {
            $accessToken = json_decode(file_get_contents($tokenPath), true);
            $client->setAccessToken($accessToken);
        }

        // If there is no previous token or it's expired.
        if ($client->isAccessTokenExpired()) {
            // Refresh the token if possible, else fetch a new one.
            if ($client->getRefreshToken()) {
                $client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
            } else {
                // Request authorization from the user.

                $authUrl = $client->createAuthUrl();
                printf("Open the following link in your browser:\n%s\n", $authUrl);
                print 'Enter verification code: ';
                $authCode = trim(fgets(STDIN));

                // Exchange authorization code for an access token.
                $accessToken = $client->fetchAccessTokenWithAuthCode($authCode);

                //$client->setAccessToken($accessToken);
                $client->setAccessToken($accessToken);

                // Check to see if there was an error.
                if (array_key_exists('error', $accessToken)) {
                    throw new Exception(join(', ', $accessToken));
                }
            }
            // Save the token to a file.
            if (!file_exists(dirname($tokenPath))) {
                mkdir(dirname($tokenPath), 0700, true);
            }
            file_put_contents($tokenPath, json_encode($client->getAccessToken()));
        }
        return $client;
    }
 $client = getClient();
$obj = new APIClass($client->getAccessToken()['access_token']);
$obj->updateNow("Temp2","100");
?>

Маленькая Помощь будет оценена .. Спасибо

1 Ответ

0 голосов
/ 06 ноября 2018

Наконец-то обнаружил, что я передаю многомерный и после передачи его в foreach он становится единым массивом, но мне нужно только строковое значение, чтобы оно решалось путем передачи одномерного массива, а также помещал ваш код в блок try catch, который мешал мне получить ' BadRequestException 'из таблицы API API

Спасибо, ребята.

...