Programmer's Reference Guide
| Google Base verwenden |
Gdata Ausnahmen auffangen
Die Zend_Gdata_App_Exception Klasse ist eine Basis Klasse für Ausnahmen die durch Zend_Gdata
geworfen werden. Man kann jede durch Zend_Gdata geworfene Ausnahme auffangen indem
Zend_Gdata_App_Exception aufgefangen wird.
<?php
try {
$client = Zend_Gdata_ClientLogin::getHttpClient($username, $password);
} catch(Zend_Gdata_App_Exception $ex) {
// Die Ausnahme an den Benutzer bekanntgeben
die($ex->getMessage());
}
Die folgenden Ausnahme Subklassen werden von Zend_Gdata verwendet:
-
Zend_Gdata_App_AuthExceptionindiziert das die Benutzer Account Daten nicht gültig sind. -
Zend_Gdata_App_BadMethodCallExceptionindiziert das eine Methode für ein Service aufgerufen wurde der diese Methode nicht unterstützt. Zum Beispiel unterstützt der CodeSearch Servicepost()nicht. -
Zend_Gdata_App_HttpExceptionindiziert das eine HTTP Anfrage nicht erfolgreich war. Bietet die Möglichkeit das komplette Zend_Http_Request Objekt zu erhalten um den exakten Grund des Fehlers festzustellen in den Fällen in denen$e->getMessage()nicht genug Details liefert. -
Zend_Gdata_App_InvalidArgumentExceptionwird geworfen wenn eine Anwendung einen Wert bietet der in dem gegebenen Kontext nicht gültig ist. Zum Beispiel wenn ein Kalender Sichtbarkeits Wert von "banana" spezifiziert wird, oder ein Blogger Feed geholt werden soll ohne einen Blog Namen zu spezifizieren. -
Zend_Gdata_App_CaptchaRequiredExceptionwird geworfen wenn ein ClientLogin Versuch stattfindet und eineCAPTCHA Challenge vom Authentifikations Service empfangen wird. Diese Ausnahme enthält eine Token ID und eine URL zu einemCAPTCHA Challenge Bild. Dieses Bild ist ein visuelles Puzzle das dem Benutzer angezeigt werden sollte. Nachdem die Antwort des Benutzers auf dieses Challenge Bild gesammelt wurde, kann die Antwort im nächsten ClientLogin Versuch inkludiert werden. Alternativ kann der Benutzer direkt zu dieser Webseite geleitet werden: https://www.google.com/accounts/DisplayUnlockCaptcha Weitere Informationen können in der ClientLogin Dokumentation gefunden werden.
Man kann diese Ausnahme Subklassen verwenden um spezielle Ausnahmen unterschiedlich zu handhaben. Siehe die API Dokumentation für Informationen darüber welche Ausnahme Subklassen durch welche Methoden in Zend_Gdata geworfen werden.
<?php
try {
$client = Zend_Gdata_ClientLogin::getHttpClient($username, $password, $service);
} catch(Zend_Gdata_App_AuthException $authEx) {
// Die Benutzer Account Daten sind nicht korrekt.
// Es wäre nett dem Benutzer einen zweiten Versuch zu geben.
...
} catch(Zend_Gdata_App_HttpException $httpEx) {
// Google Data Server konnten nicht erreicht werden.
die($httpEx->getMessage);}
| Google Base verwenden |
