Как сохранить данные в непубличной электронной таблице Google, используя PHP без библиотеки Zend Gdata? - PullRequest
4 голосов
/ 06 октября 2009

Как сохранить данные в непубличной электронной таблице Google в PHP без использования Zend Gdata lib ? Я не могу использовать Zend libs, как это показано в руководствах по Google, потому что php-сервер, на котором я запускаю скрипт, - php v. 5.0.4 . Я пытался найти решение, используя cUrl, но я не могу опустить проблему с аутентификацией, когда документ не открыт. Как мне это сделать? Если кто-то пытался это сделать, пожалуйста, поделитесь решением.

Ответы [ 3 ]

5 голосов
/ 07 октября 2009

Я нашел решение, используя curl и создав форму для электронной таблицы Google. Для подготовленной электронной таблицы необходимо создать форму без параметров: Требовать входа для просмотра этой формы и Автоматический сбор имени пользователя респондента . Затем проверьте, используя f.e. firebug, форма отправляет uri и публикует данные и использует их для следующего скрипта:

#prepare post data
$fields = array('backupCache' => '',
            'entry.0.single'=>urlencode($data['name']),
            'entry.1.single'=>urlencode($data['surname']),
            'pageNumber'=>urlencode(0),   
            'submit'=>'Submit');
$fields_string = '';

foreach($fields as $key=>$value) {
  $fields_string .= $key.'='.$value.'&';
}

rtrim($fields_string,"& ");
$fields_string = substr($fields_string, 0, strlen($fields_string)-1);

$ch = curl_init();
#set curl_setopt for your preferences
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HEADER, 0);    
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 0);    

curl_setopt($ch, CURLOPT_POST, count($fields));
curl_setopt($ch, CURLOPT_POSTFIELDS, $fields_string);

#set proper form uri
curl_setopt($ch, CURLOPT_URL, $formUri);
curl_setopt($ch, CURLOPT_TIMEOUT, 120);

$res = curl_exec($ch);
curl_close($ch);

Возможно, это не самое совершенное решение, но оно работает. :)

2 голосов
/ 28 сентября 2010

Вот объектно-ориентированный класс php для отправки данных в таблицу Google Docs - http://code.google.com/p/php-form-builder-class/source/browse/trunk/includes/class.spreadsheet.php?spec=svn384&r=384

cUrl используется вместо библиотеки Zend GData. Вы можете найти пример реализации ниже. Не забудьте заменить настройки теста ("my_google_email", "my_google_password" и т. Д.) На свои конкретные данные.

$doc = new spreadsheet();
$doc->authenticate("my_google_email", "my_google_password");
$doc->setSpreadsheet("my_spreadsheet_title");
$doc->setWorksheet("my_worksheet_title");
$my_data = array("First Name" => "John", "Last Name" => "Doe");
$doc->add($my_data);

Ключи ассоциативного массива, передаваемые методу add, должны соответствовать заголовкам столбцов электронных таблиц, которые вы используете для сбора данных.

0 голосов
/ 06 октября 2009

Вы можете получить доступ к API GData с помощью обычных HTTP-запросов; библиотека делает это проще для вас. Вы просто переписываете биты библиотеки, которую хотите использовать.

См. Документацию протокола .

...