PHPackages                             focusim/php-qrcode - 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. [Utility &amp; Helpers](/categories/utility)
4. /
5. focusim/php-qrcode

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

focusim/php-qrcode
==================

A QR code generator. PHP 8.1+

4.3.4.3(3y ago)026.2k↓22.6%MITPHPPHP ^7.4 || ^8.0

Since Dec 24Pushed 3y agoCompare

[ Source](https://github.com/Focusim/php-qrcode)[ Packagist](https://packagist.org/packages/focusim/php-qrcode)[ Docs](https://github.com/focusim/php-qrcode)[ Fund](https://www.paypal.com/donate?hosted_button_id=WLYUNAT9ZTJZ4)[ Fund](https://ko-fi.com/codemasher)[ RSS](/packages/focusim-php-qrcode/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (1)Dependencies (4)Versions (44)Used By (0)

chillerlan/php-qrcode
=====================

[](#chillerlanphp-qrcode)

A PHP 7.4+ QR Code library based on the [implementation](https://github.com/kazuhikoarase/qrcode-generator) by [Kazuhiko Arase](https://github.com/kazuhikoarase), namespaced, cleaned up, improved and other stuff.

**Attention:** there is now also a javascript port: [chillerlan/js-qrcode](https://github.com/chillerlan/js-qrcode).

[![PHP Version Support](https://camo.githubusercontent.com/04d1187595485712e2c4f20b2053b513481e324716db882a873b576b9ed0e44d/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f7068702d762f6368696c6c65726c616e2f7068702d7172636f64653f6c6f676f3d70687026636f6c6f723d383839324246)](https://www.php.net/supported-versions.php)[![Packagist version](https://camo.githubusercontent.com/aa5829b7834b343e83bedf64253c8a610a806af4c2a27bbc2ccc85ba4c436839/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f6368696c6c65726c616e2f7068702d7172636f64652e7376673f6c6f676f3d7061636b6167697374)](https://packagist.org/packages/chillerlan/php-qrcode)[![License](https://camo.githubusercontent.com/fe9cc17a4c8d8cce816966a554657646015be9bc9458a00b616707f0e0c4980d/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6963656e73652f6368696c6c65726c616e2f7068702d7172636f64652e737667)](https://github.com/chillerlan/php-qrcode/blob/main/LICENSE)[![CodeCov](https://camo.githubusercontent.com/7bff398040a322926ed0784547c0ad6489823a8487f835e5433a434eef87609d/68747470733a2f2f696d672e736869656c64732e696f2f636f6465636f762f632f6769746875622f6368696c6c65726c616e2f7068702d7172636f64652e7376673f6c6f676f3d636f6465636f76)](https://codecov.io/github/chillerlan/php-qrcode)[![Scrunitizer CI](https://camo.githubusercontent.com/a96b936456a254619bfaf5260815103b7464adfb03ca6a31c26109d954e5cae7/68747470733a2f2f696d672e736869656c64732e696f2f7363727574696e697a65722f672f6368696c6c65726c616e2f7068702d7172636f64652e7376673f6c6f676f3d7363727574696e697a6572)](https://scrutinizer-ci.com/g/chillerlan/php-qrcode)[![Packagist downloads](https://camo.githubusercontent.com/be676adaa06a668521fa7a9d8bbdfd7dc0c59858692c8b31638b08a260b256ab/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f6368696c6c65726c616e2f7068702d7172636f64652e7376673f6c6f676f3d7061636b6167697374)](https://packagist.org/packages/chillerlan/php-qrcode/stats)
[![Continuous Integration](https://github.com/chillerlan/php-qrcode/workflows/Continuous%20Integration/badge.svg)](https://github.com/chillerlan/php-qrcode/actions?query=workflow%3A%22Continuous+Integration%22+branch%3Av4.3.x)

Documentation
=============

[](#documentation)

Requirements
------------

[](#requirements)

- PHP 7.4+
    - `ext-mbstring`
    - optional:
        - `ext-json`, `ext-gd`
        - `ext-imagick` with [ImageMagick](https://imagemagick.org) installed
        - [`setasign/fpdf`](https://github.com/setasign/fpdf) for the PDF output module

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

[](#installation)

**requires [composer](https://getcomposer.org)**

via terminal: `composer require chillerlan/php-qrcode`

*composer.json*

```
{
	"require": {
		"php": "^7.4 || ^8.0",
		"chillerlan/php-qrcode": "v4.3.x-dev"
	}
}
```

Note: replace `v4.3.x-dev` with a [version constraint](https://getcomposer.org/doc/articles/versions.md#writing-version-constraints), e.g. `^4.3` - see [releases](https://github.com/chillerlan/php-qrcode/releases) for valid versions. For PHP version ...

- 7.4+ use `^4.3`
- 7.2+ use `^3.4.1` (v3.4.1 also supports PHP8)
- 7.0+ use `^2.0`
- 5.6+ use `^1.0` (please let PHP 5 die!)

In case you want to keep using `v4.3.x-dev`, specify the hash of a commit to avoid running into unforseen issues like so: `v4.3.x-dev#c115f7bc51d466ccb24c544e88329804aad8c2a0`

PSA: [PHP 7.0 - 7.3 are EOL](https://www.php.net/supported-versions.php) and therefore the respective `QRCode` versions are also no longer supported!

Quickstart
----------

[](#quickstart)

We want to encode this URI for a mobile authenticator into a QRcode image:

```
$data = 'otpauth://totp/test?secret=B3JX4VCVJDVNXNZ5&issuer=chillerlan.net';

// quick and simple:
echo '';
```

 [![QR codes are awesome!](https://raw.githubusercontent.com/chillerlan/php-qrcode/v4.3.x/examples/example_image.png)](https://raw.githubusercontent.com/chillerlan/php-qrcode/v4.3.x/examples/example_image.png) [![QR codes are awesome!](https://raw.githubusercontent.com/chillerlan/php-qrcode/v4.3.x/examples/example_svg.png)](https://raw.githubusercontent.com/chillerlan/php-qrcode/v4.3.x/examples/example_svg.png)

Wait, what was that? Please again, slower!

Advanced usage
--------------

[](#advanced-usage)

Ok, step by step. First you'll need a `QRCode` instance, which can be optionally invoked with a `QROptions` (or a [`SettingsContainerInterface`](https://github.com/chillerlan/php-settings-container/blob/master/src/SettingsContainerInterface.php), respectively) object as the only parameter.

```
$options = new QROptions([
	'version'    => 5,
	'outputType' => QRCode::OUTPUT_MARKUP_SVG,
	'eccLevel'   => QRCode::ECC_L,
]);

// invoke a fresh QRCode instance
$qrcode = new QRCode($options);

// and dump the output
$qrcode->render($data);

// ...with additional cache file
$qrcode->render($data, '/path/to/file.svg');
```

In case you just want the raw QR code matrix, call `QRCode::getMatrix()` - this method is also called internally from `QRCode::render()`. See also \[\[Custom output interface\]\].

```
$matrix = $qrcode->getMatrix($data);

foreach($matrix->matrix() as $y => $row){
	foreach($row as $x => $module){

		// get a module's value
		$value = $module;

		// or via the matrix's getter method
		$value = $matrix->get($x, $y);

		// boolean check a module
		if($matrix->check($x, $y)){ // if($module >> 8 > 0)
			// do stuff, the module is dark
		}
		else{
			// do other stuff, the module is light
		}

	}
}
```

Have a look [in the examples folder](https://github.com/chillerlan/php-qrcode/tree/main/examples) for some more usage examples.

### Notes

[](#notes)

The QR encoder, especially the subroutines for mask pattern testing, can cause high CPU load on increased matrix size. You can avoid a part of this load by choosing a fast output module, like `OUTPUT_IMAGE_*` and maybe setting the mask pattern manually (which may result in unreadable QR Codes). Oh hey and don't forget to sanitize any user input!

Custom output interface
-----------------------

[](#custom-output-interface)

Instead of bloating your code you can simply create your own output interface by creating a `QROutputInterface` (i.e. extending `QROutputAbstract`).

```
class MyCustomOutput extends QROutputAbstract{

	// inherited from QROutputAbstract
	protected QRMatrix $matrix;   // QRMatrix
	protected int $moduleCount;   // modules QRMatrix::size()
	protected QROptions $options; // MyCustomOptions or QROptions
	protected int $scale;         // scale factor from options
	protected int $length;        // length of the matrix ($moduleCount * $scale)

	// ...check/set default module values (abstract method, called by the constructor)
	protected function setModuleValues():void{
		// $this->moduleValues = ...
	}

	// QROutputInterface::dump()
	public function dump(string $file = null):string{
		$output = '';

		for($row = 0; $row < $this->moduleCount; $row++){
			for($col = 0; $col < $this->moduleCount; $col++){
				$output .= (int)$this->matrix->check($col, $row);
			}
		}

		return $output;
	}

}
```

For more examples, have a look at the [built-in output modules](https://github.com/chillerlan/php-qrcode/tree/main/src/Output).

In case you need additional settings for your output module, just extend `QROptions`...

```
class MyCustomOptions extends QROptions{
	protected string $myParam = 'defaultValue';

	// ...
}

```

...or use the [`SettingsContainerInterface`](https://github.com/chillerlan/php-settings-container/blob/main/src/SettingsContainerInterface.php), which is the more flexible approach.

```
trait MyCustomOptionsTrait{
	protected string $myParam = 'defaultValue';

	// ...
}
```

set the options:

```
$myOptions = [
	'version'         => 5,
	'eccLevel'        => QRCode::ECC_L,
	'outputType'      => QRCode::OUTPUT_CUSTOM,
	'outputInterface' => MyCustomOutput::class,
	// your custom settings
	'myParam'         => 'whatever value',
 ];

// extends QROptions
$myCustomOptions = new MyCustomOptions($myOptions);

// using the SettingsContainerInterface
$myCustomOptions = new class($myOptions) extends SettingsContainerAbstract{
	use QROptionsTrait, MyCustomOptionsTrait;
};
```

You can then call `QRCode` with the custom modules...

```
(new QRCode($myCustomOptions))->render($data);
```

...or invoke the `QROutputInterface` manually.

```
$qrOutputInterface = new MyCustomOutput($myCustomOptions, (new QRCode($myCustomOptions))->getMatrix($data));

//dump the output, which is equivalent to QRCode::render()
$qrOutputInterface->dump();
```

### Custom module values

[](#custom-module-values)

You can distinguish between different parts of the matrix, namely the several required patterns from the QR Code specification, and use them in different ways, i.e. to assign different colors for each part of the matrix (see the [image example](https://github.com/chillerlan/php-qrcode/blob/main/examples/image.php)). The dark value is the module value (light) shifted by 8 bits to the left: `$value = $M_TYPE > 8) === $M_TYPE;

// for false (light)
$value === $M_TYPE;
```

...or you can perform a loose check, ignoring the module value

```
// for true
($value >> 8) > 0;

// for false
($value >> 8) === 0;
```

See also `QRMatrix::set()`, `QRMatrix::check()` and [`QRMatrix` constants](#qrmatrix-constants).

To map the values and properly render the modules for the given `QROutputInterface`, it's necessary to overwrite the default values:

```
$options = new QROptions;

// for HTML, SVG and ImageMagick
$options->moduleValues = [
	// finder
	1536 => '#A71111', // dark (true)
	6    => '#FFBFBF', // light (false)
	// alignment
	2560 => '#A70364',
	10   => '#FFC9C9',
	// timing
	3072 => '#98005D',
	12   => '#FFB8E9',
	// format
	3584 => '#003804',
	14   => '#00FB12',
	// version
	4096 => '#650098',
	16   => '#E0B8FF',
	// data
	1024 => '#4A6000',
	4    => '#ECF9BE',
	// darkmodule
	512  => '#080063',
	// separator
	8    => '#AFBFBF',
	// quietzone
	18   => '#FFFFFF',
];

// for the image output types
$options->moduleValues = [
	512  => [0, 0, 0],
	// ...
];

// for string/text output
$options->moduleValues = [
	512  => '#',
	// ...
];
```

Public API
----------

[](#public-api)

### `QRCode` API

[](#qrcode-api)

#### Methods

[](#methods)

methodreturndescription`__construct(QROptions $options = null)`-see [`SettingsContainerInterface`](https://github.com/chillerlan/php-settings-container/blob/main/src/SettingsContainerInterface.php)`render(string $data, string $file = null)`mixed, `QROutputInterface::dump()`renders a QR Code for the given `$data` and `QROptions`, saves `$file` optional`getMatrix(string $data)``QRMatrix`returns a `QRMatrix` object for the given `$data` and current `QROptions``initDataInterface(string $data)``QRDataInterface`returns a fresh `QRDataInterface` for the given `$data``isNumber(string $string)`boolchecks if a string qualifies for `Number``isAlphaNum(string $string)`boolchecks if a string qualifies for `AlphaNum``isKanji(string $string)`boolchecks if a string qualifies for `Kanji``isByte(string $string)`boolchecks if a string is non-empty#### Constants

[](#constants)

namedescription`VERSION_AUTO``QROptions::$version``MASK_PATTERN_AUTO``QROptions::$maskPattern``OUTPUT_MARKUP_SVG`, `OUTPUT_MARKUP_HTML``QROptions::$outputType` markup`OUTPUT_IMAGE_PNG`, `OUTPUT_IMAGE_JPG`, `OUTPUT_IMAGE_GIF``QROptions::$outputType` image`OUTPUT_STRING_JSON`, `OUTPUT_STRING_TEXT``QROptions::$outputType` string`OUTPUT_IMAGICK``QROptions::$outputType` ImageMagick`OUTPUT_FPDF``QROptions::$outputType` PDF, using [FPDF](https://github.com/setasign/fpdf)`OUTPUT_CUSTOM``QROptions::$outputType`, requires `QROptions::$outputInterface``ECC_L`, `ECC_M`, `ECC_Q`, `ECC_H`,ECC-Level: 7%, 15%, 25%, 30% in `QROptions::$eccLevel``DATA_NUMBER`, `DATA_ALPHANUM`, `DATA_BYTE`, `DATA_KANJI``QRDataInterface::$datamode`### `QRMatrix` API

[](#qrmatrix-api)

#### Methods

[](#methods-1)

methodreturndescription`__construct(int $version, int $eclevel)`--`init(int $maskPattern, bool $test = null)``QRMatrix``matrix()`arraythe internal matrix representation as a 2 dimensional array`version()`intthe current QR Code version`eccLevel()`intcurrent ECC level`maskPattern()`intthe used mask pattern`size()`intthe absoulute size of the matrix, including quiet zone (if set). `$version * 4 + 17 + 2 * $quietzone``get(int $x, int $y)`intreturns the value of the module`set(int $x, int $y, bool $value, int $M_TYPE)``QRMatrix`sets the `$M_TYPE` value for the module`check(int $x, int $y)`boolchecks whether a module is true (dark) or false (light)#### Constants

[](#constants-1)

namelight (false)dark (true)description`M_NULL`0-module not set (should never appear. if so, there's an error)`M_DARKMODULE`-512once per matrix at `$xy = [8, 4 * $version + 9]``M_DATA`41024the actual encoded data`M_FINDER`61536the 7x7 finder patterns`M_SEPARATOR`8-separator lines around the finder patterns`M_ALIGNMENT`102560the 5x5 alignment patterns`M_TIMING`123072the timing pattern lines`M_FORMAT`143584format information pattern`M_VERSION`164096version information pattern`M_QUIETZONE`18-margin around the QR Code`M_LOGO`20-space for a logo image (not used yet)`M_TEST`25565280test value### `QROptions` API

[](#qroptions-api)

#### Properties

[](#properties)

propertytypedefaultalloweddescription`$version`int`QRCode::VERSION_AUTO`1...40the [QR Code version number](http://www.qrcode.com/en/about/version.html)`$versionMin`int11...40Minimum QR version (if `$version = QRCode::VERSION_AUTO`)`$versionMax`int401...40Maximum QR version (if `$version = QRCode::VERSION_AUTO`)`$eccLevel`int`QRCode::ECC_L``QRCode::ECC_X`Error correct level, where X = L (7%), M (15%), Q (25%), H (30%)`$maskPattern`int`QRCode::MASK_PATTERN_AUTO`0...7Mask Pattern to use`$addQuietzone`bool`true`-Add a "quiet zone" (margin) according to the QR code spec`$quietzoneSize`int4clamped to 0 ... `$matrixSize / 2`Size of the quiet zone`$dataModeOverride`string`null``Number`, `AlphaNum`, `Kanji`, `Byte`allows overriding the data type detection`$outputType`string`QRCode::OUTPUT_IMAGE_PNG``QRCode::OUTPUT_*`built-in output type`$outputInterface`string`null`\*FQCN of the custom `QROutputInterface` if `QROptions::$outputType` is set to `QRCode::OUTPUT_CUSTOM``$cachefile`string`null`\*optional cache file path`$eol`string`PHP_EOL`\*newline string (HTML, SVG, TEXT)`$scale`int5\*size of a QR code pixel (SVG, IMAGE\_\*), HTML -&gt; via CSS`$cssClass`string`null`\*a common css class`$svgOpacity`float1.00...1`$svgDefs`string\*\*anything between [``](https://developer.mozilla.org/docs/Web/SVG/Element/defs)`$svgViewBoxSize`int`null`\*a positive integer which defines width/height of the [viewBox attribute](https://css-tricks.com/scale-svg/#article-header-id-3)`$textDark`string'🔴'\*string substitute for dark`$textLight`string'⭕'\*string substitute for light`$markupDark`string'#000'\*markup substitute for dark (CSS value)`$markupLight`string'#fff'\*markup substitute for light (CSS value)`$imageBase64`bool`true`-whether to return the image data as base64 or raw like from `file_get_contents()``$imageTransparent`bool`true`-toggle transparency (no jpeg support)`$imageTransparencyBG`array`[255, 255, 255]``[R, G, B]`the RGB values for the transparent color, see [`imagecolortransparent()`](http://php.net/manual/function.imagecolortransparent.php)`$pngCompression`int-1-1 ... 9`imagepng()` compression level, -1 = auto`$jpegQuality`int850 - 100`imagejpeg()` quality`$imagickFormat`string'png'\*ImageMagick output type, see `Imagick::setType()``$imagickBG`string`null`\*ImageMagick background color, see `ImagickPixel::__construct()``$moduleValues`array`null`\*Module values map, see \[\[Custom output interface\]\] and `QROutputInterface::DEFAULT_MODULE_VALUES`Framework Integration
---------------------

[](#framework-integration)

- Drupal:
    - [Google Authenticator Login `ga_login`](https://www.drupal.org/project/ga_login)
- Symfony
    - [phpqrcode-bundle](https://github.com/jonasarts/phpqrcode-bundle)
- WordPress:
    - [`wp-two-factor-auth`](https://github.com/sjinks/wp-two-factor-auth)
    - [`simple-2fa`](https://wordpress.org/plugins/simple-2fa/)
    - [`wordpress-seo`](https://github.com/Yoast/wordpress-seo)
    - [`floating-share-button`](https://github.com/qriouslad/floating-share-button)
- WoltLab Suite
    - [two-step-verification](http://pluginstore.woltlab.com/file/3007-two-step-verification/)
- [Appwrite](https://github.com/appwrite/appwrite)
- [Cachet](https://github.com/CachetHQ/Cachet)
- [twill](https://github.com/area17/twill)
- other uses: [dependents](https://github.com/chillerlan/php-qrcode/network/dependents) / [packages](https://github.com/chillerlan/php-qrcode/network/dependents?dependent_type=PACKAGE)

Shameless advertising
---------------------

[](#shameless-advertising)

Hi, please check out my other projects that are way cooler than qrcodes!

- [php-oauth-core](https://github.com/chillerlan/php-oauth-core) - an OAuth 1/2 client library along with a bunch of [providers](https://github.com/chillerlan/php-oauth-providers)
- [php-httpinterface](https://github.com/chillerlan/php-httpinterface) - a PSR-7/15/17/18 implemetation
- [php-database](https://github.com/chillerlan/php-database) - a database client &amp; querybuilder for MySQL, Postgres, SQLite, MSSQL, Firebird

Disclaimer!
-----------

[](#disclaimer)

I don't take responsibility for molten CPUs, misled applications, failed log-ins etc.. Use at your own risk!

### Trademark Notice

[](#trademark-notice)

The word "QR Code" is a registered trademark of *DENSO WAVE INCORPORATED*

###  Health Score

39

—

LowBetter than 86% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity28

Limited adoption so far

Community11

Small or concentrated contributor base

Maturity81

Battle-tested with a long release history

 Bus Factor1

Top contributor holds 98.3% 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

Every ~50 days

Recently: every ~13 days

Total

40

Last Release

1098d ago

Major Versions

3.3.0 → 4.1.02020-06-04

3.4.0 → 4.3.12021-01-05

3.4.1 → 4.3.22021-11-18

v3.2.x-dev → 4.3.42022-07-25

4.3.4 → 5.0-beta2023-03-22

PHP version history (6 changes)2.0.0PHP &gt;=7.0.3

1.0.8PHP &gt;=5.6.0

3.0.0PHP ^7.2

4.0.0PHP ^7.4

4.2.0PHP ^7.4 || ^8.0

3.4.1PHP ^7.2 || ^8.0

### Community

Maintainers

![](https://www.gravatar.com/avatar/a305c57f5bf7726a89af7926637e76fd95e2926ed4ef482a846802bb94a63546?d=identicon)[Focusim](/maintainers/Focusim)

---

Top Contributors

[![codemasher](https://avatars.githubusercontent.com/u/592497?v=4)](https://github.com/codemasher "codemasher (507 commits)")[![MaximilianKresse](https://avatars.githubusercontent.com/u/545671?v=4)](https://github.com/MaximilianKresse "MaximilianKresse (5 commits)")[![joshstoik1](https://avatars.githubusercontent.com/u/403248?v=4)](https://github.com/joshstoik1 "joshstoik1 (2 commits)")[![darthmaim](https://avatars.githubusercontent.com/u/2511547?v=4)](https://github.com/darthmaim "darthmaim (1 commits)")[![kmvan](https://avatars.githubusercontent.com/u/3839554?v=4)](https://github.com/kmvan "kmvan (1 commits)")

---

Tags

qr codeqrcodeqrphpqrcodeqrcode-generator

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/focusim-php-qrcode/health.svg)

```
[![Health](https://phpackages.com/badges/focusim-php-qrcode/health.svg)](https://phpackages.com/packages/focusim-php-qrcode)
```

###  Alternatives

[chillerlan/php-qrcode

A QR Code generator and reader with a user-friendly API. PHP 8.4+

2.4k28.9M208](/packages/chillerlan-php-qrcode)[endroid/qr-code

Endroid QR Code

4.8k67.6M348](/packages/endroid-qr-code)[amirezaeb/heroqr

A Powerful QR Code Management Library For PHP

9510.3k](/packages/amirezaeb-heroqr)[arcanedev/qr-code

QR Code generator

1231.9k1](/packages/arcanedev-qr-code)[devtical/nova-qrcode-field

Nova QR code field

4560.6k2](/packages/devtical-nova-qrcode-field)[linkxtr/laravel-qrcode

A clean, modern, and easy-to-use QR code generator for Laravel

295.1k](/packages/linkxtr-laravel-qrcode)

PHPackages © 2026

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