Google 提供了一个用于与 Ad Manager API 进行交互的 Java 客户端库。 我们建议将客户端库与 Apache Maven 或 Gradle 结合使用。
首先,在您选择的 IDE 中创建一个新项目,或将
现有项目依赖项Google 将客户端库工件发布到
将 Maven 中央代码库
com.google.api-ads/ad-manager
。
Maven
<!-- pom.xml -->
<dependency>
<groupId>com.google.api-ads</groupId>
<artifactId>ad-manager</artifactId>
<version>0.1.0</version>
</dependency>
Gradle
implementation 'com.google.api-ads:ad-manager:0.1.0'
配置凭据
Java 客户端库使用 OAuth2 和应用默认凭据 (ADC) 进行身份验证。
ADC 在以下位置按顺序搜索凭据:
GOOGLE_APPLICATION_CREDENTIALS
环境变量。- 通过 Google Cloud CLI (gcloud CLI) 设置的用户凭据。
- 在 Google Cloud 上运行时,是指关联到 Google Cloud 资源的服务账号。
如需了解如何创建和配置 ADC 凭据,请参阅 身份验证。
发出第一个请求
每项服务都有一个同时包含同步和异步数据的 ServiceClient
对象
方法。以下示例读取了一个 Network
。
import com.google.ads.admanager.v1.GetNetworkRequest;
import com.google.ads.admanager.v1.Network;
import com.google.ads.admanager.v1.NetworkName;
import com.google.ads.admanager.v1.NetworkServiceClient;
public class SyncGetNetwork {
public static void main(String[] args) throws Exception {
syncGetNetwork();
}
public static void syncGetNetwork() throws Exception {
try (NetworkServiceClient networkServiceClient = NetworkServiceClient.create()) {
GetNetworkRequest request =
GetNetworkRequest.newBuilder()
.setName(NetworkName.of("[NETWORK_CODE]").toString())
.build();
Network response = networkServiceClient.getNetwork(request);
}
}
}
如需查看其他方法和资源的示例,请参阅 GitHub 代码库
googleapis/google-cloud-java
。
记录 HTTP 请求和响应
com.google.api.client.http.HttpTransport
类会发出所有 HTTP 请求。
这个类使用
java.util.logging
(JUL) 用于记录 HTTP 请求和响应详细信息,包括网址、标头和
内容。
要启用日志记录,请将此类的日志记录器级别设置为
CONFIG
或更高版本。具体操作步骤因日志记录类型而异
您使用的实现方式。
7 月
如需启用日志记录,请将 com.google.api.client.http.level
设置为 CONFIG
或
位于 logging.properties
文件中。
handlers=java.util.logging.ConsoleHandler
com.google.api.client.http.level=CONFIG
java.util.logging.ConsoleHandler.level=CONFIG
或者,您也可以在 Java 代码中启用日志记录。
import com.google.api.client.http.HttpTransport;
import java.util.logging.ConsoleHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
public static void enableLogging() {
Logger logger = Logger.getLogger(HttpTransport.class.getName());
logger.setLevel(Level.CONFIG);
ConsoleHandler handler = new ConsoleHandler();
handler.setLevel(Level.CONFIG);
logger.addHandler(handler);
}
Log4j
如果您使用 Log4j 进行日志记录,可以使用
Log4j JDK 日志记录适配器
记录 JUL 消息。这可以通过 SystemProperty
或
方法是使用 Log4jBridgeHandler
和 JUL logging.properties
文件。
系统属性
-Djava.util.logging.manager=org.apache.logging.log4j.jul.LogManager
Log4j 桥接处理程序
handlers = org.apache.logging.log4j.jul.Log4jBridgeHandler
org.apache.logging.log4j.jul.Log4jBridgeHandler.propagateLevels = true
这些设置会将 Ad Manager API 日志写入级别为
CONFIG
或更高版本。以下示例 log4j2.xml
文件将
写入 System.out
的日志记录器。
<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
<Appenders>
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout pattern="%m%n"/>
</Console>
</Appenders>
<Loggers>
<Logger name="com.google.api.client.http.HttpTransport" level="debug">
<AppenderRef ref="Console"/>
</Logger>
<Root level="error">
<AppenderRef ref="Console"/>
</Root>
</Loggers>
</Configuration>
处理错误
所有 Ad Manager API 错误都是 ApiException 。
除 404 Not Found
和 401 Unauthorized
之外的所有错误都包含 ErrorDetails
并提供额外的信息
解析错误
错误原因字段唯一标识错误类型。使用 以确定如何处理错误。
ErrorDetails errorDetails = apiException.getErrorDetails();
if (errorDetails != null) {
// Unique error code in UPPER_SNAKE_CASE.
String errorCode = errorDetails.getReason();
}
Ad Manager API 错误还包含一个唯一的 request_id
,您可以
向支持团队提供以下方面的帮助:
问题排查。以下示例提取了
request_id
。
ErrorDetails errorDetails = apiException.getErrorDetails();
if (errorDetails != null && errorDetails.getRequestInfo() != null) {
// Unique request identifier.
String requestId = errorDetails.getRequestInfo().getRequestId();
}
构造资源名称
客户端库提供辅助类,用于从命令行构建资源名称 。
import com.google.ads.admanager.v1.OrderName;
// ...
// Constructs a String in the format:
// "networks/{networkCode}/orders/{orderId}"
OrderName.of("123", "789");
配置代理设置
Java 客户端库同时支持 http.proxyHost
和 https.proxyHost
系统属性设置。如需详细了解这些设置,请参阅
Java 网络和代理。