Google Data API (GData)

September 10, 2011


Yesterday on StackOverflow I came across a question about using the Google Data API (also called GData) in .NET. Questions about it regularly pop up. Retrieving my Google data in .NET somehow seems appealing to me, but maybe that’s just me. I never worked with it before, so I took some time to experiment with it a bit. Figured I’d better write it down, before I forget it again. This article is a quick introduction on using the Google Data API with the .NET Framework…so, let’s get started…

Table Of Contents

Google Data .NET Client Library

Google offers official client libraries for GData for several programming languages such as Java, .NET, Phyton and Objective-C (they even have a partial library for JavaScript). So the first thing you have to do, is to download the .NET client library from

You can download the .NET client library (+/- 27.7 Mb) here:

At the time of writing the most recent version is Under the downloads section just select the MSI installation wizard package. Installing the SDK is really simple. Just click next three times and close once and you’re done.

Installing Google Data API SDK

NuGet Tip: Instead of installing the MSI install NuGet instead and add a reference to the Google Data API packages. Google Inc. was kind enough to make them available as NuGet packages. Each assembly of the Google Data Client library has been put in a seperate package. You can view a list of these packages here.

Remark: If you don’t install the MSI you won’t get the Visual Studio project templates that come with it. The next two parts of this text discuss these templates, so if you want to follow along, it is best to download and install the MSI. You can always switch to the NuGet packages later.

Top of page

Project Templates

Before you rush off and start Visual Studio 2010 you need to fix a small thing. Open Windows Explorer and navigate to the “My Documents” library and open the Visual Studio 2008 project templates folder. In this folder you’ll notice a new folder called “Google”, if you open it you’ll notice it contains seven new project templates.

My Documents > Visual Studio 2008 > Templates > ProjectTemplates > Visual C# > Google

Project Templates

Now you need to copy the Google folder over to the Visual Studio 2010 project templates folder (My Documents > Visual Studio 2008 > Templates > ProjectTemplates > Visual C# &gt).

If you start Visual Studio 2010 now and create a new project you’ll notice that it contains the new Google project templates.

New Project - Google Project Templates

Top of page

Google Project Template

Let’s play around with one of the Google project templates. Create a new project and select the Google Contacts project template. Let’s be *original* and call it “Google Contacts”.

Most of the Google project templates contain the same structure. It’s a simple Windows Forms application that contains two forms. A login form and another one that displays the data (contacts, calender, photos…) you are querying.

Solution Explorer

If you start the application it will ask you to enter your Google account details.

Google Client Login

After logging in it will display a simple form that lists the first 25 people found in your contacts list.

Google Contacts

Remark: I replaced the actual names in my contacts list for this demo. I don’t really know that many people named “John Smith”.

Feel free to explore the other Google Project Templates. They are all very similar.

Top of page

Using The Client Library

Querying data with the Google Data API usually consists out of three steps:

  1. Setup a connection with the API (Google.GData.Client.Service)
  2. Query the API (Google.GData.Contacts.ContactsQuery)
  3. Iterate the returned data feed (Google.GData.Contacts.ContactsFeed)

Let’s demonstrate how this is done by building a small console application that downloads the contacts just like Google’s own project template does.

Start up Visual Studio 2010, create a new blank solution called Google and add a new console application project called Contacts.

Solution Explorer - Google Data API

Add a reference to the following assemblies provided by the Google Data .NET Client library:

  • Google.GData.Client.dll
  • Google.GData.Contacts.dll
  • Google.GData.Extensions.dll

Or use NuGet to add a reference to the packages that contain these assemblies. The packages are named the same as the assemblies so you can’t miss them.

NuGet Package Manager

First create a new service instance and give it a name (doesn’t really matter how you name it).

Service service = new ContactsService("My Contacts Application");

Then you must request an authentication token.

service.setUserCredentials("", "yourpassword");
var token = service.QueryClientLoginToken();

After you’re authenticated you can compose a query to request the contact data.

var uri = ContactsQuery.CreateContactsUri("");
var query = new ContactsQuery(uri);

Now you are ready to request the data.

ContactsFeed feed = (ContactsFeed) service.Query(query);
foreach(ContactEntry contact in feed.Entries)

The previous code sample requests the first 25 contacts and writes their names to the console output. The Google Data API automatically chunks your data into several pieces. Just check the feed’s NextChunk property to check if there is more data available. If there is, you can create and execute a new query to retrieve the next chunk of data.

if (!String.IsNullOrEmpty(feed.NextChunk))
    query = new ContactsQuery(feed.NextChunk);
    feed = (ContactsFeed) service.Query(query);

Voila, you can now download your Google contact data. If you don’t want to copy/paste these code samples you can always download the source code from the download page. Just alter the code to make sure valid credentials are used.

That wraps it up. If you want to further explore the Google Data .NET Client library be sure to check out the help file (*.chm) which is installed if you use the MSI installation wizard. It contains information on all of the classes, members, constructors, properties…etc. that are available in the SDK.

Reference docs about the .NET client library are also available online. You can find them here:

If you have any questions or suggestions please drop me an e-mail or submit a comment.

Top of page

%d bloggers like this: