Wenn Sie eine Anfrage an die Google Ads API senden, kann sie aus verschiedenen Gründen fehlschlagen. Möglicherweise haben Sie ein ungültiges Argument angegeben oder in Ihrem Konto wurde das Limit für die Erstellung neuer Kampagnen erreicht. In solchen Fällen gibt die API einen Fehler zurück, um Sie darüber zu informieren, was schiefgelaufen ist.
In diesem Leitfaden wird erläutert, wie Sie API-Fehler lesen und behandeln können, um robustere Anwendungen zu entwickeln.
Fehlerstruktur
Wenn Sie eine unserer Clientbibliotheken verwenden, werden API-Fehler als Ausnahmen angezeigt. Diese Ausnahmen enthalten Details, die Ihnen helfen, die Ursache des Fehlers zu verstehen.
Die Google Ads API gibt Fehlerinformationen in einem Standardformat zurück. Wenn ein Fehler auftritt, enthält die Antwort ein GoogleAdsFailure-Objekt. Dieses Objekt enthält eine Liste einzelner GoogleAdsError-Objekte, die jeweils einen bestimmten Fehler beschreiben.
Jedes GoogleAdsError-Objekt bietet:
error_code: Ein bestimmter Fehlercode, der den Fehlertyp angibt, z. B.AuthenticationError.NOT_ADS_USER.message: Eine für Menschen lesbare Beschreibung des Grunds für den Fehler.trigger: Der Wert, der den Fehler verursacht hat, z. B. „1234“.location: Details dazu, welcher Teil der Anfrage den Fehler verursacht hat, z. B. ein bestimmter Feldname.
Zusätzlich zur Liste der Fehler enthält GoogleAdsFailure eine requestId, eine eindeutige Kennzeichnung für die API-Anfrage, die zu einem Fehler geführt hat.
Beispiel für Fehlermeldung
Hier sehen Sie ein Beispiel für einen Fehler im JSON-Format. Dieser Fehler weist darauf hin, dass das Feld name des ad_group am Index 0 in der Anfrage fehlt.
{
"code": 3,
"message": "Request contains an invalid argument.",
"details": [
{
"@type": "type.googleapis.com/google.ads.googleads.v22.errors.GoogleAdsFailure",
"errors": [
{
"errorCode": {
"requestError": "REQUIRED_FIELD_MISSING"
},
"message": "Required field is missing",
"location": {
"fieldPathElements": [
{
"fieldName": "ad_group",
"index": 0
},
{
"fieldName": "name"
}
]
}
}
],
"requestId": "unique_request_id_12345"
}
]
}
Weitere Informationen zu API-Fehlern finden Sie in unserem Leitfaden.
Beispiele für Clientbibliotheken
Im folgenden Abschnitt wird beschrieben, wie Fehler in verschiedenen Clientbibliotheken behandelt werden.
Java
try {
// Make an API call.
...
} catch (GoogleAdsException gae) {
// GoogleAdsException is the base class for most exceptions thrown by an API request.
// Instances of this exception have a message and a GoogleAdsFailure that contains a
// collection of GoogleAdsErrors that indicate the underlying causes of the
// GoogleAdsException.
System.err.printf(
"Request ID %s failed due to GoogleAdsException. Underlying errors:%n",
gae.getRequestId());
int i = 0;
for (GoogleAdsError googleAdsError : gae.getGoogleAdsFailure().getErrorsList()) {
System.err.printf(" Error %d: %s%n", i++, googleAdsError);
}
}
C#
try
{
// Make an API call.
...
}
catch (GoogleAdsException e)
{
Console.WriteLine($"Request with ID '{e.RequestId}' has failed.");
Console.WriteLine("Google Ads failure details:");
foreach (GoogleAdsError error in e.Failure.Errors)
{
Console.WriteLine($"{error.ErrorCode}: {error.Message}");
}
}
PHP
try {
// Make an API call.
...
} catch (GoogleAdsException $googleAdsException) {
printf(
"Request with ID '%s' has failed.%sGoogle Ads failure details:%s",
$googleAdsException->getRequestId(),
PHP_EOL,
PHP_EOL
);
foreach ($googleAdsException->getGoogleAdsFailure()->getErrors() as $error) {
/** @var GoogleAdsError $error */
printf(
"\t%s: %s%s",
$error->getErrorCode()->getErrorCode(),
$error->getMessage(),
PHP_EOL
);
}
}
Python
try:
# Make an API call.
...
except GoogleAdsException as ex:
print(
f"Request with ID '{ex.request_id}' failed with status "
f"'{ex.error.code().name}' and includes the following errors:"
)
for error in ex.failure.errors:
print(f"\tError with message '{error.message}' and code '{error.error_code}'.")
Ruby
begin
# Make an API call.
...
rescue Google::Ads::GoogleAds::Errors::GoogleAdsError => e
puts "API call failed with request ID: #{e.request_id}"
e.failure.errors.each do |error|
puts "\t#{error.error_code}: #{error.message}"
end
end
Perl
# Try sending a mutate request to add the ad group ad.
...
if ($response->isa("Google::Ads::GoogleAds::GoogleAdsException")) {
printf "Google Ads failure details:\n";
foreach my $error (@{$response->get_google_ads_failure()->{errors}}) {
printf "\t%s: %s\n", [keys %{$error->{errorCode}}]->[0], $error->{message};
}
}
Protokolle erfassen
Um Fehler zu beheben, erfassen Sie die vom Google Ads API-Server zurückgegebenen Fehlerprotokolle und prüfen Sie deren Inhalt. Folgen Sie der Anleitung unten, um die Protokollierung zu aktivieren und API-Logs zu erfassen.
Java
Eine Anleitung finden Sie im Leitfaden zur Protokollierung der Java-Clientbibliothek.
C#
Sie können die Protokollierung initialisieren, indem Sie die folgende Zeile in Ihre Main-Methode einfügen, bevor Sie API-Aufrufe ausführen. So wird sichergestellt, dass die Bibliothek Logs für alle API-Aufrufe generiert, die von Ihrer Anwendung ausgeführt werden.
using Google.Ads.GoogleAds.Util;
...
// Detailed logs.
TraceUtilities.Configure(TraceUtilities.DETAILED_REQUEST_LOGS_SOURCE,
"/path/to/your/logs/details.log", System.Diagnostics.SourceLevels.All);
// Summary logs.
TraceUtilities.Configure(TraceUtilities.SUMMARY_REQUEST_LOGS_SOURCE,
"/path/to/your/logs/summary.log", System.Diagnostics.SourceLevels.All);
Weitere Optionen finden Sie im Leitfaden zur.NET-Bibliotheksanmeldung.
PHP
Sie können die Logging-Konfiguration in der Datei google_ads_php.ini Ihrer Clientbibliothek festlegen. Legen Sie den logLevel auf NOTICE fest, um mit der Erfassung der detaillierten Fehlerlogs zu beginnen.
[LOGGING]
; Optional logging settings.
logFilePath = "path/to/your/file.log"
logLevel = "NOTICE"
Eine Anleitung finden Sie im Leitfaden zur Protokollierung der PHP-Clientbibliothek.
Python
Sie können die Logging-Konfiguration in der Datei google-ads.yaml Ihrer Clientbibliothek festlegen. Legen Sie die Logging-Ebene auf DEBUG fest, um mit der Erfassung der detaillierten Fehlerlogs zu beginnen.
Weitere Optionen finden Sie in der Anleitung zum Logging in der Python-Bibliothek.
Ruby
Sie können die Logging-Konfiguration in der Datei google_ads_config.rb Ihrer Clientbibliothek festlegen. Legen Sie die Logging-Ebene auf INFO fest, um mit der Erfassung der detaillierten Fehlerlogs zu beginnen.
Weitere Optionen finden Sie in der Anleitung zum Logging mit der Ruby-Bibliothek.
Perl
Fügen Sie die folgende Zeile in Ihr Perl-Skript ein, bevor Sie API-Aufrufe ausführen, um die Protokollierung zu initialisieren.
Google::Ads::GoogleAds::Logging::GoogleAdsLogger::enable_all_logging();
Weitere Optionen finden Sie in der Anleitung zum Logging der Perl-Bibliothek.
curl
curl gibt die fehlgeschlagenen Antworten standardmäßig in stderr aus.
Fehlerbehandlung
Wenn ein Fehler auftritt, gehen Sie so vor:
- Ausnahme abfangen und Logs erfassen: Fangen Sie zuerst die Ausnahmen ab und erfassen Sie optional die API-Logs.
errors-Liste prüfen: Sehen Sie sich jedesGoogleAdsError-Objekt imGoogleAdsFailure-Objekt an. Dieerror_codeundmessagegeben Aufschluss darüber, was schiefgelaufen ist.location-Wert prüfen: Mit dem Feldlocationkönnen Sie herausfinden, an welcher Stelle in Ihrer Anfrage das Problem aufgetreten ist.- Dokumentation aufrufen: Weitere Informationen zu bestimmten Fehlercodes finden Sie auf der Seite Häufige Fehler oder in der vollständigen Referenz zu Fehlercodes.
- Anfrage anpassen: Korrigieren Sie Ihre API-Anfrage anhand der Fehlermeldung. Wenn Sie beispielsweise
REQUIRED_FIELD_MISSINGsehen, müssen Sie dieses Feld in Ihrer Anfrage angeben. request_idprotokollieren: Wenn Sie nicht herausfinden können, wie Sie einen Fehler beheben, und den Support kontaktieren müssen, fügen Sie die vollständigen Anfrage- und Antwortprotokolle für die fehlgeschlagene Anfrage ein. Achten Sie darauf, dass das Flagrequest_idangegeben ist. Anhand dieser ID können Google-Techniker die Details der fehlgeschlagenen Anfrage in den Serverprotokollen der Google Ads API finden und Ihr Problem untersuchen.
Nächste Schritte
- Unter Häufige Fehler finden Sie eine Liste häufig auftretender Probleme und deren Lösungen.
- Weitere Informationen zu erweiterten Techniken zur Fehlerbehandlung, einschließlich Wiederholungslogik und Teilausfall, finden Sie unter API-Fehler verstehen.