Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Pull request Compare This branch is 1530 commits behind Azure:master.
Fetching latest commit...
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.

Windows Azure SDK for Java

This SDK allows you to build Windows Azure applications in Java that allow you to take advantage of Azure scalable cloud computing resources: table and blob storage, messaging through Service Bus.

For documentation please see the Windows Azure Java Developer Center


  • Blob
    • Create/Read/Update/Delete Blobs
  • Queue
    • Create/Delete Queues
    • Insert/Peek Queue Messages
    • Advanced Queue Operations
  • Media Services
    • Upload Media Files to Media Services
    • Change the encoding on uploaded Media Services
    • Provide streaming or download access to uploaded/transformed Media Files
  • Service Bus
    • Use either the Queue or Topic/Subscription Model
  • Service Runtime
    • Retrieve information about the state of your Azure Compute instances
  • Table
    • Manage Tables
    • Table Entity Operations
    • Entity Group Transactions (Batch)

Getting Started


Option 1: Via Git

To get the source code of the SDK via git just type:

git clone git://
cd ./azure-sdk-for-java
mvn compile

Option 2: Via Maven

To get the binaries of this library as distributed by Microsoft, ready for use within your project you can also have them installed by the Java package manager Maven.


Minimum Requirements

  • Java 1.6
  • (Optional) Maven


To use this SDK to call Windows Azure services, you need to first create an account. To host your Java code in Windows Azure, you additionally need to download the full Windows Azure SDK for Java - which includes packaging, emulation, and deployment tools.

Code Samples

The following is a quick example on how to set up a Azure blob using the API and uploading a file to it. For additional information on using the client libraries to access Azure services see the How To guides listed here.


public class BlobSample {
    public static final String storageConnectionString = 
        "DefaultEndpointsProtocol=http;" + 
        "AccountName=your_account_name;" + 
        "AccountKey= your_account_name"; 

    public static void main(String[] args) 
            CloudStorageAccount account;
            CloudBlobClient serviceClient;
            CloudBlobContainer container;
            CloudBlockBlob blob;

            account = CloudStorageAccount.parse(storageConnectionString);
            serviceClient = account.createCloudBlobClient();
            // Container name must be lower case.
            container = serviceClient.getContainerReference("blobsample");

            // Set anonymous access on the container.
            BlobContainerPermissions containerPermissions;
            containerPermissions = new BlobContainerPermissions();

            // Upload an image file.
            blob = container.getBlockBlobReference("image1.jpg");
            File fileReference = new File ("c:\\myimages\\image1.jpg");
            blob.upload(new FileInputStream(fileReference), fileReference.length());
        catch (FileNotFoundException fileNotFoundException)
            System.out.print("FileNotFoundException encountered: ");
        catch (StorageException storageException)
            System.out.print("StorageException encountered: ");
        catch (Exception e)
            System.out.print("Exception encountered: ");


Need Help?

Be sure to check out the Windows Azure Developer Forums on Stack Overflow if you have trouble with the provided code.

Contribute Code or Provide Feedback

If you would like to become an active contributor to this project please follow the instructions provided in Windows Azure Projects Contribution Guidelines.

If you encounter any bugs with the library please file an issue in the Issues section of the project.

Learn More

Something went wrong with that request. Please try again.