Java

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 在以下位置按顺序搜索凭据:

  1. GOOGLE_APPLICATION_CREDENTIALS 环境变量。
  2. 通过 Google Cloud CLI (gcloud CLI) 设置的用户凭据。
  3. 在 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 Found401 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.proxyHosthttps.proxyHost 系统属性设置。如需详细了解这些设置,请参阅 Java 网络和代理