PHPackages                             mizbanpaytakht/backblaze-b2 - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [File &amp; Storage](/categories/file-storage)
4. /
5. mizbanpaytakht/backblaze-b2

ActiveLibrary[File &amp; Storage](/categories/file-storage)

mizbanpaytakht/backblaze-b2
===========================

An SDK for working with B2 cloud storage.

1.0.0(4y ago)08LGPL-3.0-or-laterPHPPHP &gt;=7.0.0

Since Feb 21Pushed 4y ago1 watchersCompare

[ Source](https://github.com/mizbanpaytakht/backblaze-b2)[ Packagist](https://packagist.org/packages/mizbanpaytakht/backblaze-b2)[ Docs](https://github.com/mizbanpaytakht/backblaze-b2)[ RSS](/packages/mizbanpaytakht-backblaze-b2/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (1)Dependencies (5)Versions (2)Used By (0)

Backblaze B2 SDK for PHP
------------------------

[](#backblaze-b2-sdk-for-php)

[![Software License](https://camo.githubusercontent.com/2bc95db9d4d6b319fe40fe1a46431a18f9684b30d516775115c5d0df6aa3e9b4/68747470733a2f2f696d672e736869656c64732e696f2f62616467652f6c6963656e73652d4c47504c2d627269676874677265656e2e7376673f7374796c653d666c61742d737175617265)](LICENSE.md)

`backblaze-b2` is a client library for working with Backblaze's B2 storage service. It aims to make using the service as easy as possible by exposing a clear API and taking influence from other SDKs that you may be familiar with.

This package will **cache authorization request** for 1 hour so that you won't receive API Limit from B2.

This version works with both master key and application key, and version 2 (look below).

Example
-------

[](#example)

This is just a short example, full examples to come on the wiki.

```
use mizbanpaytakht\B2\Client;
use mizbanpaytakht\B2\Bucket;

$client = new Client('accountId', [
	'keyId' => 'your-key-id', // optional if you want to use master key (account Id)
	'applicationKey' => 'your-application-key',
]);
$client->version = 2; // By default will use version 1
$client->domainAliases = [ // When you want to use your own domains (using CNAME)
		'f0001.backblazeb2.com' => 'alias01.mydomain.com',
	];
$client->largeFileLimit = 3000000000; // Lower limit for using large files upload support. Default: 3GB

// Returns a Bucket object.
$bucket = $client->createBucket([
    'BucketName' => 'my-special-bucket',
    'BucketType' => Bucket::TYPE_PRIVATE // or TYPE_PUBLIC
]);

// Create a new Key.
$bucket = $client->createKey([
    'capabilities' => ['listKeys', 'writeKeys', 'deleteKeys', 'listAllBucketNames', 'listBuckets', 'readBuckets', 'writeBuckets', 'deleteBuckets', 'readBucketRetentions', 'writeBucketRetentions', 'readBucketEncryption', 'writeBucketEncryption', 'listFiles', 'readFiles', 'shareFiles', 'writeFiles', 'deleteFiles', 'readFileLegalHolds', 'writeFileLegalHolds', 'readFileRetentions', 'writeFileRetentions','bypassGovernance'],
    'keyName' => 'Key-Name',
    'bucketId' => $bucket->getId(),
    'namePrefix' => 'Prefix',
]);

// Change the bucket to private. Also returns a Bucket object.
$updatedBucket = $client->updateBucket([
    'BucketId' => $bucket->getId(),
    'BucketType' => Bucket::TYPE_PUBLIC
]);

// Retrieve an array of Bucket objects on your account.
$buckets = $client->listBuckets();

// Delete a bucket.
$client->deleteBucket([
    'BucketId' => '4c2b957661da9c825f465e1b'
]);

// Upload a file to a bucket. Returns a File object.
$file = $client->upload([
    'BucketName' => 'my-special-bucket',
    'FileName' => 'path/to/upload/to',
    'Body' => 'I am the file content'

    // The file content can also be provided via a resource.
    // 'Body' => fopen('/path/to/input', 'r')
]);

// Download a file from a bucket. Returns the file content.
$fileContent = $client->download([
    'FileId' => $file->getId()

    // Can also identify the file via bucket and path:
    // 'BucketName' => 'my-special-bucket',
    // 'FileName' => 'path/to/file'

    // Can also save directly to a location on disk. This will cause download() to not return file content.
    // 'SaveAs' => '/path/to/save/location'
]);

// Delete a file from a bucket. Returns true or false.
$fileDelete = $client->deleteFileFromArray([
    'FileId' => $file->getId()

    // Can also identify the file via bucket and path:
    // 'BucketName' => 'my-special-bucket',
    // 'FileName' => 'path/to/file'
]);

// Retrieve an array of file objects from a bucket.
$fileList = $client->listFilesFromArray([
    'BucketId' => '4d2dbbe08e1e983c5e6f0d12'
]);
```

Installation
------------

[](#installation)

Installation is via Composer:

```
$ composer require mizbanpaytakht/backblaze-b2
```

Tests
-----

[](#tests)

Tests are run with PHPUnit. After installing PHPUnit via Composer (under development):

```
$ vendor/bin/phpunit
```

Contributors
------------

[](#contributors)

Feel free to contribute in any way you can whether that be reporting issues, making suggestions or sending PRs. :)

License
-------

[](#license)

LGPL.

###  Health Score

20

—

LowBetter than 14% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity4

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity44

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

1541d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/206930f1e4a086d995b1fdef9f0ce9a2bc76387e98111772d3d087bda853986e?d=identicon)[mizbanpaytakht](/maintainers/mizbanpaytakht)

---

Top Contributors

[![mizbanpaytakht](https://avatars.githubusercontent.com/u/2773653?v=4)](https://github.com/mizbanpaytakht "mizbanpaytakht (4 commits)")

---

Tags

filesystemcloudbackupstorageb2backblazebackblaze-b2backblaze-api

### Embed Badge

![Health badge](/badges/mizbanpaytakht-backblaze-b2/health.svg)

```
[![Health](https://phpackages.com/badges/mizbanpaytakht-backblaze-b2/health.svg)](https://phpackages.com/packages/mizbanpaytakht-backblaze-b2)
```

###  Alternatives

[obregonco/backblaze-b2

An SDK for working with B2 cloud storage.

2732.9k](/packages/obregonco-backblaze-b2)[gliterd/backblaze-b2

PHP SDK for working with backblaze B2 cloud storage.

84263.3k8](/packages/gliterd-backblaze-b2)[cwhite92/b2-sdk-php

A SDK for working with B2 cloud storage.

74146.6k2](/packages/cwhite92-b2-sdk-php)[aedart/athenaeum

Athenaeum is a mono repository; a collection of various PHP packages

255.2k](/packages/aedart-athenaeum)[innoge/laravel-rclone

A sleek PHP wrapper around rclone with Laravel-style fluent API syntax

174.1k](/packages/innoge-laravel-rclone)[bringyourownideas/laravel-backblaze

Backblaze B2 Cloud Storage for Laravel 5. Original by Paul Olthof (@hpolthof) continued by @bringyourownideas

1237.8k](/packages/bringyourownideas-laravel-backblaze)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
