Нет описания

smiley 06a3ca7438 :octocat: 2 лет назад
.github a27d133457 :shower: php habits... 3 лет назад
.idea 4f3ddbc205 :octocat: 4 лет назад
.phan 23388e14ad :shower: 3 лет назад
docs 4e03cdcc85 :octocat: moved readme images 4 лет назад
examples 426c16a89b :octocat: QRMarkupSVG: extract path() method to allow modification of the individual <path> elements 2 лет назад
src d48fbd78da :octocat: QRCode::addEciSegment(): encode from mb_internal_encoding() instead of mb_detect_encoding() 2 лет назад
tests 99e84efaa3 :octocat: added Hanzi (GB2312/GB18030) mode according to GBT18284-2000 2 лет назад
.editorconfig 6a2bad4e34 :sparkles: +editorconfig 4 лет назад
.gitignore 1fd3109339 :octocat: mute debug output on CI 3 лет назад
.scrutinizer.yml b0fb84f578 :shower: 3 лет назад
LICENSE-ASL-2.0 66c0b69ffb :octocat: added Apache-2.0 license 3 лет назад
LICENSE-MIT 66c0b69ffb :octocat: added Apache-2.0 license 3 лет назад
NOTICE 66c0b69ffb :octocat: added Apache-2.0 license 3 лет назад
README.md 06a3ca7438 :octocat: 2 лет назад
composer.json 54629fea50 :octocat: 3 лет назад
phpdoc.xml a4ff33a171 :octocat: 5 лет назад
phpunit.xml.dist 571d3ea1d9 :octocat: mute debug output 2 лет назад

README.md

chillerlan/php-qrcode

A PHP QR Code library based on the implementation by Kazuhiko Arase, namespaced, cleaned up, improved and other stuff. It also features a QR Code reader which is based on the ZXing library.

Attention: there is now also a javascript port: chillerlan/js-qrcode.

PHP Version Support Packagist version License Continuous Integration CodeCov Scrunitizer CI Packagist downloads

Features

  • Generation of Model 2 QR Codes, Version 1 to 40
  • ECC Levels L/M/Q/H supported
  • Mixed mode support (encoding modes can be mixed as needed within a QR symbol)
    • Supported modes: numeric, alphanumeric, 8-bit binary as well as the double-byte modes kanji (Japanese, Shift-JIS) and hanzi (simplified Chinese, GB2312/GB18030)
  • Flexible, easily extensible output modules
  • Built-in support for the following output formats:
    • GdImage
    • ImageMagick
    • Markup types: SVG, HTML, etc.
    • String types: JSON, plain text, etc.
    • Encapsulated Postscript (EPS)
    • PDF via FPDF
  • QR Code reader (via GD and ImageMagick)

Documentation

See the wiki for advanced documentation. An API documentation created with phpDocumentor can be found at https://chillerlan.github.io/php-qrcode/ (WIP).

Requirements

For the QRCode reader, either ext-gd or ext-imagick is required!

Installation

requires composer

via terminal:

composer require chillerlan/php-qrcode

via composer.json:

{
	"require": {
		"php": "^7.4 || ^8.0",
		"chillerlan/php-qrcode": "dev-main"
	}
}

Note: replace dev-main with a version constraint, e.g. ^4.3 - see releases for valid versions. See the installation guide on the wiki for more info!

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 '<img src="'.(new QRCode)->render($data).'" alt="QR Code" />';

QR codes are awesome!

Wait, what was that? Please again, slower! See Advanced usage on the wiki. Also, have a look in the examples folder for some more usage examples.

Reading QR Codes

Using the built-in QR Code reader is pretty straight-forward:

$result = (new QRCode)->readFromFile('path/to/file.png'); // -> DecoderResult

// you can now use the result instance...
$content = $result->data;
$matrix  = $result->getMatrix(); // -> QRMatrix

// ...or simply cast it to string to get the content:
$content = (string)$result;

It's generally a good idea to wrap the reading in a try/catch block to handle any errors that may occur in the process.

Framework Integration

Shameless advertising

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

Disclaimer!

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

License notice

Parts of this code are ported to php from the ZXing project and licensed under the Apache License, Version 2.0.

Trademark Notice

The word "QR Code" is a registered trademark of DENSO WAVE INCORPORATED
https://www.qrcode.com/en/faq.html#patentH2Title