azure-storage-php/README.md

154 строки
6.4 KiB
Markdown
Исходник Обычный вид История

2016-04-20 07:53:36 +03:00
# Microsoft Azure Storage SDK for PHP
This project provides a set of PHP client libraries that make it easy to access Microsoft Azure Storage services (blobs, tables and queues). For documentation on how to host PHP applications on Microsoft Azure, please see the [Microsoft Azure PHP Developer Center](http://www.windowsazure.com/en-us/develop/php/).
> **Note**
>
> If you are looking for the Service Bus, Service Runtime, Service Management or Media Services libraries, please visit https://github.com/Azure/azure-sdk-for-php.
# Features
* Blobs
* create, list, and delete containers, work with container metadata and permissions, list blobs in container
* create block and page blobs (from a stream or a string), work with blob blocks and pages, delete blobs
* work with blob properties, metadata, leases, snapshot a blob
* Tables
* create and delete tables
* create, query, insert, update, merge, and delete entities
* batch operations
* Queues
* create, list, and delete queues, and work with queue metadata and properties
* create, get, peek, update, delete messages
Please check details on [API reference documents](http://azure.github.io/azure-storage-php).
2016-04-20 07:53:36 +03:00
# Getting Started
## Minimum Requirements
* PHP 5.5 or above
* See [composer.json](composer.json) for dependencies
* Required extension for PHP:
php_fileinfo.dll
php_mbstring.dll
php_openssl.dll
php_xsl.dll
* Recommanded extension for PHP:
php_curl.dll
2016-04-20 07:53:36 +03:00
## Download Source Code
To get the source code from GitHub, type
git clone https://github.com/Azure/azure-storage-php.git
cd ./azure-storage-php
## Install via Composer
1. Create a file named **composer.json** in the root of your project and add the following code to it:
```json
{
"require": {
"microsoft/azure-storage": "*"
}
}
```
2. Download **[composer.phar](http://getcomposer.org/composer.phar)** in your project root.
3. Open a command prompt and execute this in your project root
php composer.phar install
## Usage
There are four basic steps that have to be performed before you can make a call to any Microsoft Azure Storage API when using the libraries.
* First, include the autoloader script:
require_once "vendor/autoload.php";
* Include the namespaces you are going to use.
To create any Microsoft Azure service client you need to use the **ServicesBuilder** class:
use MicrosoftAzure\Storage\Common\ServicesBuilder;
To process exceptions you need:
use MicrosoftAzure\Storage\Common\ServiceException;
* To instantiate the service client you will also need a valid [connection string](https://azure.microsoft.com/en-us/documentation/articles/storage-configure-connection-string/). The format is:
DefaultEndpointsProtocol=[http|https];AccountName=[yourAccount];AccountKey=[yourKey]
* Instantiate a client object - a wrapper around the available calls for the given service.
```PHP
$tableClient = ServicesBuilder::getInstance()->createTableService($connectionString);
$blobClient = ServicesBuilder::getInstance()->createBlobService($connectionString);
$queueClient = ServicesBuilder::getInstance()->createQueueService($connectionString);
```
### Using Middlewares
To specify the middlewares, user have to create an array with middlewares
and put it in the `$requestOptions` with key 'middlewares'. The sequence of
the array will affect the sequence in which the middleware is invoked. The
`$requestOptions` can usually be set in the options of an API call, such as
`MicrosoftAzure\Storage\Blob\Models\ListBlobOptions`.
The user can push the middleware into the array with key 'middlewares' in
services' `$_options` instead when creating them if the middleware is to be
applied to each of the API call for a rest proxy. These middlewares will always
be invoked after the middlewares in the `$requestOptions`.
e.g.:
2016-04-20 07:53:36 +03:00
```
$tableClient = ServicesBuilder::getInstance()->createTableService(
$connectionString,
$optionsWithMiddlewares
);
```
Each of the middleware should be either an instance of a sub-class that
implements `MicrosoftAzure\Storage\Common\Internal\IMiddleware`, or a
`callable` that follows the Guzzle middleware implementation convention.
User can create self-defined middleware that inherits from `MicrosoftAzure\Storage\Common\Internal\Middlewares\MiddlewareBase`.
2016-04-20 07:53:36 +03:00
## Troubleshooting
### Error: Unable to get local issuer certificate
cURL can't verify the validity of Microsoft certificate when trying to issue a request call to Azure Storage Services. You must configure cURL to use a certificate when issuing https requests by the following steps:
1. Download the cacert.pem file from [cURL site](http://curl.haxx.se/docs/caextract.html).
2. Open your php.ini file and add the following line:
```
curl.cainfo = "<absolute path to cacert.pem>"
```
2016-04-20 07:53:36 +03:00
## Code samples
You can find samples in the [sample folder](samples)
# Migrate from [Azure SDK for PHP](https://github.com/Azure/azure-sdk-for-php/)
If you are using [Azure SDK for PHP](https://github.com/Azure/azure-sdk-for-php/) to access Azure Storage Service, we highly recommend you to migrate to this SDK for faster issue resolution and quicker feature implementation. We are working on supporting the latest service features (including SAS, CORS, append blob, file service, etc) as well as improvement on existing APIs.
2016-08-19 10:51:21 +03:00
For now, Microsoft Azure Storage SDK for PHP v0.10.2 shares almost the same interface as the storage blobs, tables and queues APIs in Azure SDK for PHP v0.4.3. However, there are some minor breaking changes need to be addressed during your migration. You can find the details in [BreakingChanges.md](BreakingChanges.md).
2016-04-20 07:53:36 +03:00
Please note that this library is still in preview and may contain more breaking changes in upcoming releases.
# Need Help?
Be sure to check out the Microsoft Azure [Developer Forums on Stack Overflow](http://go.microsoft.com/fwlink/?LinkId=234489) and [github issues](https://github.com/Azure/azure-storage-php/issues) 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 [Azure Projects Contribution Guidelines](http://azure.github.io/guidelines/).
You can find more details for contributing in the [CONTRIBUTING.md](CONTRIBUTING.md).
If you encounter any bugs with the library please file an issue in the [Issues](https://github.com/Azure/azure-storage-php/issues) section of the project.