This project hosts the Java client library for the various SOAP-Based Ads APIs (AdWords, DFA, and DFP) at Google.
- Distributed via Maven
- Uses the SLF4J logging facade to log requests and SOAP messages, allowing you to plug in a concrete logging framework of your choice.
- Automatic handling of SOAP headers
- Easy management of credentials, authentication, and session information
- JavaDoc
- Java 1.6+
- Maven 3.0+ not required, but recommended
For API and client library updates and news, please follow our Google+ Ads Developers page and our Google Ads Developers blog
If you have questions about the client library or the APIs, you can ask them on our forums:
- AdWords API Forum
- DoubleClick for Publishers API Forum
- DoubleClick for Advertisers API Forum
- DoubleClick Ad Exchange Buyer API Forum
<dependency>
<groupId>com.google.api-ads</groupId>
<artifactId>ads-lib</artifactId>
<version>RELEASE</version>
</dependency>
<dependency>
<groupId>com.google.api-ads</groupId>
<artifactId>adwords-axis</artifactId>
<version>RELEASE</version>
</dependency>
<dependency>
<groupId>com.google.api-ads</groupId>
<artifactId>ads-lib</artifactId>
<version>RELEASE</version>
</dependency>
<dependency>
<groupId>com.google.api-ads</groupId>
<artifactId>dfa-axis</artifactId>
<version>RELEASE</version>
</dependency>
<dependency>
<groupId>com.google.api-ads</groupId>
<artifactId>ads-lib</artifactId>
<version>RELEASE</version>
</dependency>
<dependency>
<groupId>com.google.api-ads</groupId>
<artifactId>dfp-axis</artifactId>
<version>RELEASE</version>
</dependency>
Note: The following explanation is for AdWords and Axis, but the general idea applies to all products and frameworks.
The "ads-lib" artifact contains all of the library and utility classes for accessing the Ads API, but does not support any specific SOAP framework. All client library classes and utilities are in the package or sub-packages of "com.google.api.ads.common.lib". To add support for the AdWords API using the Apache Axis framework, the "adwords-axis" plugin artifact is also necessary. This artifact also includes autogenerated classes from the AdWords API. They are in the package "com.google.api.ads.adwords.{version}".
You have the option to use jars or Maven. While we suggest using Maven, we understand that not all build environments can handle this.
You will need to register an OAuth2 application to get a valid client ID and secret. See the Using OAuth 2 wiki page for more information.
In the releases section download a file like adwords-axis-jars-and-examples-v.vv.vv.tar.gz
and extract it.
- Modify
You will need to modify the ads.properties
file with your settings. This can be moved (not copied) to your home directory as well.
$ vim ads.properties
- Import
Import the eclipse project by going to File > Import, then General > Existing projects into workspace and selecting the extracted folder.
- Authenticate
Now, generate OAuth2 credentials to be used with other examples. Navigate in your project to src/adwords/axis/auth/GetRefreshToken.java
and run the example.
Copy the refresh token into your ads.properties file as you just did with your general settings and client ID/secret when prompted.
- Run example
Navigate in your project to any example (e.g., src/adwords/axis/<version>/basicoperations/GetCampaigns.java
) and run the example.
In the releases section download a file like adwords-axis-maven-and-examples-v.vv.vv.tar.gz
and extract it.
- Modify
You will need to modify the src/main/resources/ads.properties
file with your settings. This can be moved (not copied) to your home directory as well.
$ vim src/main/resources/ads.properties
- Import
Import the eclipse project by going to File > Import, then General > Existing projects into workspace and selecting the extracted folder.
- Authenticate
Now, generate OAuth2 credentials to be used with other examples. Navigate in your project to src/main/java/adwords/axis/auth/GetRefreshToken.java
and run the example.
Copy the refresh token into your src/main/resources/ads.properties
file as you just did with your general settings and client ID/secret when prompted.
- Run example
Navigate in your project to any example (e.g., src/adwords/axis/<version>/basicoperations/GetCampaigns.java
) and run the example.
In the releases section download a file like adwords-axis-maven-and-examples-v.vv.vv.tar.gz
and extract it.
- Modify
You will need to modify the src/main/resources/ads.properties
file with your settings. This can be moved (not copied) to your home directory as well.
$ vim src/main/resources/ads.properties
- Authenticate
Now, generate OAuth2 credentials to be used with other examples.
$ cd path/to/extracted/distribution
$ mvn -X compile
$ mvn -X exec:java -Dexec.mainClass="adwords.axis.auth.GetRefreshToken"
Copy the refresh token into your src/main/resources/ads.properties
file as you just did with your general settings and client ID/secret when prompted.
You must have Maven recompile every time you modify the source code or resources in order for your changes to take effect.
$ mvn -X compile
- Run example
This command runs the GetCampaigns
example, but you can update the -Dexec.mainClass
argument with the example of your choice.
$ mvn -X exec:java -Dexec.mainClass="adwords.axis.v201502.basicoperations.GetCampaigns"
The following example is for AdWords and Axis, but the general code applies to all products and frameworks.
// Contains the data classes and service classes.
import com.google.api.ads.adwords.axis.v201502.*;
import com.google.api.ads.adwords.lib.client.AdWordsSession;
import com.google.api.ads.adwords.lib.axis.factory.AdWordsServices;
public static void main(String[] args) throws Exception {
/**
* Create an AdWordsSession instance, loading credentials from the
* properties file:
*/
// Get an OAuth2 credential.
Credential credential = new OfflineCredentials.Builder()
.forApi(OfflineCredentials.Api.AdWords)
.fromFile()
.build()
.generateCredential();
// Construct an AdWordsSession.
AdWordsSession session = new AdWordsSession.Builder()
.fromFile()
.withOAuth2Credential(credential)
.build();
/**
* Alternatively, you can specify your credentials in the constructor:
*/
// Get an OAuth2 credential.
credential = new OfflineCredentials.Builder()
.forApi(OfflineCredentials.Api.AdWords)
.withClientSecrets(clientId, clientSecret)
.withRefreshToken(refreshToken)
.build()
.generateCredential();
// Construct an AdWordsSession.
session = new AdWordsSession.Builder()
.withDeveloperToken(developerToken)
// ...
.withOAuth2Credential(credential)
.build();
/**
* Instantiate the desired service class using the AdWordsServices utility and a
* Class object representing your service.
*/
// Get the CampaignService.
CampaignServiceInterface campaignService =
new AdWordsServices().get(session, CampaignServiceInterface.class);
/**
* Create data objects and invoke methods on the service class instance. The
* data objects and methods map directly to the data objects and requests for
* the corresponding web service.
*/
// Create selector.
Selector selector = new Selector();
selector.setFields(new String[] {"Id", "Name"});
// Get all campaigns.
CampaignPage page = campaignService.get(selector);
}
The client library uses SLF4J for all logging. If you want to turn logging on, you must include a plugin that bridges SLF4J with a concrete logging framework. To quickly get you started and to serve as an example of how to do this, this example distribution uses the log4j framework.
There are the following loggers within the library:
-
com.google.api.ads.adwords.lib.client.AdWordsServiceClient.soapXmlLogger com.google.api.ads.dfa.lib.client.DfaServiceClient.soapXmlLogger com.google.api.ads.dfp.lib.client.DfpServiceClient.soapXmlLogger
Logs incoming and outgoing SOAP requests/responses. SOAP requests and responses are logged as WARN for exceptions and INFO for all other requests. You can configure your logging framework to accept logs on these parameters. See the example log4j.properties for more information.
-
com.google.api.ads.adwords.lib.client.AdWordsServiceClient.requestInfoLogger com.google.api.ads.dfa.lib.client.DfaServiceClient.requestInfoLogger com.google.api.ads.dfp.lib.client.DfpServiceClient.requestInfoLogger
Logs all requests from the client library along with information such as the timestamp, service, method, endpoint URL.
Because the client library uses SLF4J, the behavior of these loggers is highly customizable. Please see the "log4j.properties" or "src/main/resources/log4j.properties" file for details on the default behavior in this example project.
To use a different framework than log4j, remove the slf4j-log4j12 jar from your classpath and fetch a different one here: http://www.slf4j.org/download.html
To bridge SLF4J for a logging framework, you must do the following:
-
Include the plugin and logging framework dependencies in the pom.xml file's dependencies list.
log4j log4j 1.2.16 org.slf4j slf4j-log4j12 1.7.7 -
If your logging framework requires a configuration file, you must place it in the resources directory. This distribution includes an example configuration for log4j named "log4j.properties".
First, add an entry to your ads.properties
file for each API you plan to use.
# AdWords
api.adwords.useCompression=true
# DFP
api.dfp.useCompression=true
# DFA
api.dfa.useCompression=true
If using JaxWs, then no further steps are required.
If using Axis, then no further steps are required unless you are setting the
axis.ClientConfigFile
system property. If you are setting
axis.ClientConfigFile
to your own custom WSDD file and you want to use
compression, please ensure that the http
transport defined in your WSDD
supports compression.
It is recommended that the user set JVM arguments to configure this application for their proxy.
https.proxyHost Hostname of proxy server web-proxy
https.proxyPort Port on server of proxy 8080
https.proxyUser Optional username for proxy authentication someone
https.proxyPassword Optional proxy server password secret
These properties can be set with java args in your eclipse run configuration:
-Dhttps.proxyHost=web-proxy -Dhttps.proxyPort=8080 -Dhttps.proxyUser=someone
-Dhttps.proxyPassword=secret ...
If necessary, set this up in code by doing the following:
System.setProperty("https.proxyHost", "web-proxy");
System.setProperty("https.proxyPort", "8080");
System.setProperty("https.proxyUser", "someone");
System.setProperty("https.proxyPassword", "secret");
All of these items can be submitted at (https://github.com/googleads/googleads-java-lib/issues)