The Azure Storage Client Library for C++ allows you to build applications against Microsoft Azure Storage. For an overview of Azure Storage, see Introduction to Microsoft Azure Storage.
There is an alternative client library that requires minimum dependency, which provides basic object storage that Blob service offers. Please see azure-storage-cpplite for more information.
- Tables
- Create/Delete Tables
- Query/Create/Read/Update/Delete Entities
- Blobs
- Create/Read/Update/Delete Blobs
- Queues
- Create/Delete Queues
- Insert/Peek Queue Messages
- Advanced Queue Operations
- Files
- Create/Delete/Resize Shares
- Create/Delete Directories
- Create/Read/Update/Delete Files
For the best development experience, we recommend that developers use the vcpkg as the cross-platform library manager.
To call Azure services, you must first have an Azure subscription. Sign up for a free trial or use your MSDN subscriber benefits.
Be sure to check out the Azure Storage Forum on MSDN if you need help, or use StackOverflow.
We gladly accept community contributions.
- Issues: Report bugs on the Issues page in GitHub.
- Forums: Communicate with the Azure Storage development team on the Azure Storage Forum or StackOverflow.
- Source Code Contributions: Please follow the contribution guidelines for Azure open source for instructions about contributing to the source project.
For general suggestions about Azure, use our Azure feedback forum.
To build with source code, there are three ways to install dependencies:
-
Via vcpkg
You can manage the dependencies with vcpkg, and use Visual Studio 2015 update 3 or Visual Studio 2017 for development environment. Simply installing Casablanca via vcpkg will setup everything needed.
C:\src\vcpkg> .\vcpkg install cpprestsdk
If you want to build and run test code, you can install UnitTest++ via vcpkg:
C:\src\vcpkg> .\vcpkg install unittest-cpp
-
Via NuGet
Because Casablanca does not release NuGet packages anywhere anymore, Starting from 5.1.0, this repository cannot be built with pre-built Casablanca NuGet packages. However, you can export your own version of Casablanca NuGet packages to install dependencies of this project:
C:\src\vcpkg> .\vcpkg install cpprestsdk C:\src\vcpkg> .\vcpkg export --nuget cpprestsdk --nuget-id=Casablanca --nuget-version=2.10.18
-
Manage dependencies by yourself
It is not recommended to manage dependencies by yourself. However, you can still build Casablanca by yourself by following these instructions and specify the include directories and link binaries.
To create a local clone of the source for the Azure Storage Client Library for C++ via git, type:
git clone https://github.com/Azure/azure-storage-cpp.git
cd azure-storage-cpp
Follow Getting Started on Linux or Getting Started on macOS to build on these two platforms.
To build on Windows, directly open the solution file with Visual Studio in project root directory.
Starting from version 6.1.0, Azure Storage Client Library for C++ supports Visual Studio 2015 and Visual Studio 2017. In case you have the need to use Visual Studio 2013, please get version 6.0.0, to use Visual Studio 2012, please get version 2.0.0.
To install the binaries for the Azure Storage Client Library for C++, you can export a NuGet package with vcpkg and put it into your local NuGet feed. For more information about how to export a NuGet package, please see Binary Export.
Normally, exporting NuGet package is done with the following command:
C:\src\vcpkg> .\vcpkg export --nuget azure-storage-cpp --nuget-id=Microsoft.Azure.Storage.CPP --nuget-version=7.1.0
To install the Azure Storage Client Library for C++ through vcpkg, you need vcpkg installed first. Please follow the instructions(https://github.com/Microsoft/vcpkg#quick-start) to install vcpkg.
Install package with:
C:\src\vcpkg> .\vcpkg install azure-storage-cpp
The Azure Storage Client Library for C++ depends on the C++ REST SDK (codename "Casablanca") It can be installed through vcpkg (vcpkg install cpprestsdk
) or downloaded directly from GitHub.
The validated Casablanca version for each major or recent release on different platforms can be found in the following chart:
azure-storage-cpp's version | Casablanca version for Windows | Casablanca version for Linux |
---|---|---|
1.0.0 | 2.4.0 | 2.4.0 |
2.0.0 | 2.4.0 | 2.4.0 |
3.0.0 | 2.9.1 | 2.9.1 |
4.0.0 | 2.9.1 | 2.9.1 |
5.0.0 | 2.9.1 | 2.9.1 |
5.0.1 | 2.9.1 | 2.9.1 |
5.1.0 | 2.10.6 | 2.10.3 |
5.1.1 | 2.10.6 | 2.10.3 |
5.2.0 | 2.10.6 | 2.10.3 |
6.0.0 | 2.10.10 | 2.10.10 |
6.1.0 | 2.10.13 | 2.10.13 |
7.0.0 | 2.10.14 | 2.10.14 |
7.1.0 | 2.10.14 | 2.10.14 |
7.2.0 | 2.10.14 | 2.10.14 |
7.3.0 | 2.10.15 | 2.10.15 |
7.3.1 | 2.10.15 | 2.10.15 |
7.4.0 | 2.10.16 | 2.10.16 |
7.5.0 | 2.10.18 | 2.10.18 |
To get started with the coding, please visit the following articles:
- How to use Blob Storage from C++
- How to use Table Storage from C++
- How to use Queue Storage from C++
To accomplish specific tasks, please find the code samples at samples folder.
As mentioned above, the Azure Storage Client Library for C++ depends on Casablanca. Follow these instructions to compile it.
Once this is complete, then:
- Clone the project using git:
git clone https://github.com/Azure/azure-storage-cpp.git
The project is cloned to a folder called azure-storage-cpp
. Always use the master branch, which contains the latest release.
- Install additional dependencies:
sudo apt-get install libxml2-dev uuid-dev
- Build the SDK for Release:
cd azure-storage-cpp/Microsoft.WindowsAzure.Storage
mkdir build.release
cd build.release
CASABLANCA_DIR=<path to Casablanca> CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release
make
In the above command, replace <path to Casablanca>
to point to your local installation of Casablanca. For example, if the file libcpprest.so
exists at location ~/Github/Casablanca/cpprestsdk/Release/build.release/Binaries/libcpprest.so
, then your cmake
command should be:
CASABLANCA_DIR=~/Github/Casablanca/cpprestsdk CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release
The library is generated under azure-storage-cpp/Microsoft.WindowsAzure.Storage/build.release/Binaries/
.
To build and run unit tests:
- Install UnitTest++ library:
sudo apt-get install libunittest++-dev
- Build the test code:
CASABLANCA_DIR=<path to Casablanca> CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release -DBUILD_TESTS=ON
make
- Run unit tests
cd Binaries
vi test_configurations.json # modify test config file to include your storage account credentials
./azurestoragetest
To build sample code:
vi ../samples/SamplesCommon/samples_common.h # modify connection string to include your storage account credentials
CASABLANCA_DIR=<path to Casablanca> CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release -DBUILD_SAMPLES=ON
make
To run the samples:
cd Binaries
./azurestoragesample
Please note the current build script is only tested on Ubuntu 16.04. Please update the script accordingly for other distributions.
Please note that starting from 2.10.0, Casablanca requires a minimum version of CMake v3.1, so the default CMake on Ubuntu 14.04 cannot support Casablanca build. User can upgrade CMake by themselves to build Casablanca. If default CMake (2.8) for Ubuntu 14.04 must be used, 5.0.1 with Casablanca version v2.9.1 is recommended.
Please note the following build script is only tested on SLES12 SP3. The script may need to be updated accordingly for other distributions.
Before building the Azure Storage Client Library on C++, some prerequisites need to be installed first:
- Install prerequisites:
sudo zypper install git gcc-c++ boost-devel cmake libopenssl-devel libxml2-devel libuuid-devel
The Azure Storage Client Library for C++ depends on Casablanca, following are instructions to build and install Casablanca:
- Clone the project using git:
git clone https://github.com/Microsoft/cpprestsdk.git
- Checkout the version on which Azure Storage Client Library for C++ depends:
git checkout tags/v2.10.18 -b v2.10.18
- Build the project in Release mode
cd cpprestsdk/Release
git submodule update --init
mkdir build.release
cd build.release
CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release -DWERROR=OFF -DBUILD_SAMPLES=OFF -DBUILD_TESTS=OFF
sudo make install
To build the Azure Storage Client Library for C++ project:
- Clone the project using git:
git clone https://github.com/Azure/azure-storage-cpp.git
The project is cloned to a folder called azure-storage-cpp
. Always use the master branch, which contains the latest release.
- Build the SDK in Release mode:
cd azure-storage-cpp/Microsoft.WindowsAzure.Storage
mkdir build.release
cd build.release
CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release
make
The library is generated under azure-storage-cpp/Microsoft.WindowsAzure.Storage/build.release/Binaries/
.
The Azure Storage Client Library for C++ project depends on Unitest++ for unit test:
To build and install Unitest++:
- Clone the project using git:
git clone https://github.com/unittest-cpp/unittest-cpp.git
- Build and install the project:
cd unittest-cpp/builds/
CXX=g++-5.1 cmake ..
sudo make install
Build and run unit test against Azure Storage Client Library for C++:
- Build the test code:
CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release -DBUILD_TESTS=ON
make
- Run unit tests
cd Binaries
vi test_configurations.json # modify test config file to include your storage account credentials
./azurestoragetest
To build sample code:
vi ../samples/SamplesCommon/samples_common.h # modify connection string to include your storage account credentials
CXX=g++-5.1 cmake .. -DCMAKE_BUILD_TYPE=Release -DBUILD_SAMPLES=ON
make
To run the samples:
cd Binaries
./azurestoragesample
Please note the following build script is only tested on CentOS 6.10 and 7.6. The script may need to be updated accordingly for other distributions.
Before building the Azure Storage Client Library on C++, some prerequisites need to be installed first:
- Install prerequisites:
sudo yum install epel-release centos-release-scl
sudo yum install git cmake3 make openssl-devel libxml2-devel libuuid-devel
- Install and enable to use gcc-c++. Note that
devtoolset-4
may be not available on some platforms, you can choose to install whichever newer than that, likedevtoolset-8
.
sudo yum install devtoolset-4-gcc-c++
scl enable devtoolset-4 bash
- Download and install boost
wget https://dl.bintray.com/boostorg/release/1.68.0/source/boost_1_68_0.tar.gz
tar xvf boost_1_68_0.tar.gz
cd boost_1_68_0
./bootstrap.sh
sudo ./b2 install
The Azure Storage Client Library for C++ depends on Casablanca, following are instructions to build and install Casablanca:
- Clone the project using git:
git clone https://github.com/Microsoft/cpprestsdk.git
- Checkout the version on which Azure Storage Client Library for C++ depends:
cd cpprestsdk
git checkout tags/v2.10.18 -b v2.10.18
- Build the project in Release mode
git submodule update --init
mkdir Release/build.release
cd Release/build.release
cmake3 .. -DCMAKE_BUILD_TYPE=Release -DWERROR=OFF -DBUILD_SAMPLES=OFF -DBUILD_TESTS=OFF
sudo make install
To build the Azure Storage Client Library for C++ project:
- Clone the project using git:
git clone https://github.com/Azure/azure-storage-cpp.git
The project is cloned to a folder called azure-storage-cpp
. Always use the master branch, which contains the latest release.
- Build the SDK in Release mode:
cd azure-storage-cpp/Microsoft.WindowsAzure.Storage
mkdir build.release
cd build.release
cmake3 .. -DCMAKE_BUILD_TYPE=Release
make
The library is generated under azure-storage-cpp/Microsoft.WindowsAzure.Storage/build.release/Binaries/
.
The Azure Storage Client Library for C++ project depends on Unitest++ for unit test:
To build and install Unitest++:
- Clone the project using git:
git clone https://github.com/unittest-cpp/unittest-cpp.git
- Build and install the project:
cd unittest-cpp/builds/
cmake3 ..
sudo make install
Build and run unit test against Azure Storage Client Library for C++:
- Build the test code:
cmake3 .. -DCMAKE_BUILD_TYPE=Release -DBUILD_TESTS=ON
make
- Run unit tests
cd Binaries
vi test_configurations.json # modify test config file to include your storage account credentials
./azurestoragetest
- To build sample code:
vi ../samples/SamplesCommon/samples_common.h # modify connection string to include your storage account credentials
cmake3 .. -DCMAKE_BUILD_TYPE=Release -DBUILD_SAMPLES=ON
make
- To run the samples:
cd Binaries
./azurestoragesample
Note that macOS is not officially supported yet, but it has been seen to work, YMMV. This build has been tested to work when the dependencies are installed via homebrew, YMMV if using FINK or MacPorts
Install dependecies with homebrew:
brew install libxml2 ossp-uuid openssl
As mentioned above, the Azure Storage Client Library for C++ depends on Casablanca. If you are using homebrew you can install it from there:
brew install cpprestsdk
Otherwise, you may need to build it. Follow these instructions to compile it.
Once this is complete, then:
- Clone the project using git:
git clone https://github.com/Azure/azure-storage-cpp.git
The project is cloned to a folder called azure-storage-cpp
. Always use the master branch, which contains the latest release.
Some notes about building:
-
If you're using homebrew, there seems to be an issue with the pkg-config files, which means that, by default, a -L flag to tell the linker where libintl lives is left out. We've accounted for this in our CMAKE file, by looking in the usual directory that homebrew puts those libs. If you are not using homebrew, you will get an error stating that you need to tell us where those libs live.
-
Similarly, for openssl, you don't want to use the version that comes with macOS, it is old. We've accounted for this in the CMAKE script by setting the search paths to where homebrew puts openssl, so if you're not using homebrew you'll need to tell us where a more recent version of openssl lives.
-
Build the SDK for Release if you are using hombrew:
cd azure-storage-cpp/Microsoft.WIndowsAzure.Storage
mkdir build.release
cd build.release
cmake .. -DCMAKE_BUILD_TYPE=Release
make
- OR, Build the SDK for Release if you are not using homebrew
cd azure-storage-cpp/Microsoft.WindowsAzure.Storage
mkdir build.release
cd build.release
CASABLANCA_DIR=<path to casablanca> cmake .. -DCMAKE_BUILD_TYPE=Release -DOPENSSL_ROOT_DIR=<path to openssl> -DGETTEXT_LIB_DIR=<path to gettext lib dir>
make
In the above command, replace:
<path to Casablanca>
to point to your local installation of Casablanca. For example, if the filelibcpprest.so
exists at location~/Github/Casablanca/cpprestsdk/Release/build.release/Binaries/libcpprest.dylib
, then should be~/Github/Casablanca/cpprestsdk
<path to openssl>
to your local openssl, it is recommended not to use the version that comes with macOS, rather use one from Homebrew or the like. This should be the path that contains thelib
andinclude
directories<path to gettext lib dir>
is the directory which containslibintl.dylib
For example you might use:
CASABLANCA_DIR=~/Github/Casablanca/cpprestsdk cmake .. -DCMAKE_BUILD_TYPE=Release -DOPENSSL_ROOT_DIR=/usr/local/opt/openssl -DGETTEXT_LIB_DIR=/usr/local/opt/gettext/lib
The library is generated under azure-storage-cpp/Microsoft.WindowsAzure.Storage/build.release/Binaries/
.
To build and run unit tests:
- Install UnitTest++ library:
brew install unittest-cpp
- Build the test code:
cmake .. -DCMAKE_BUILD_TYPE=Release -DBUILD_TESTS=ON
make
- Run unit tests
cd Binaries
vi test_configurations.json # modify test config file to include your storage account credentials
./azurestoragetest