hranicka / qr-platba
Generating payment QR codes for the Czech Republic.
Requires
- php: >=8.2
- ext-mbstring: *
- endroid/qr-code: ^6.0.3
- jschaedl/iban-validation: ^v2.5.1
Requires (Dev)
- fpdf/fpdf: ^1.84
- phpunit/phpunit: ^9
This package is not auto-updated.
Last update: 2024-12-18 10:31:57 UTC
README
Knihovna pro generování QR plateb v PHP. QR platba zjednodušuje koncovému uživateli
provedení příkazu k úhradě, protože obsahuje veškeré potřebné údaje, které stačí jen
naskenovat. Nově lze použít i jiné měny než CZK a to pomocí metody setCurrenty($currency)
.
Tato knihovna umožňuje:
- zobrazení obrázku v
<img>
tagu, který obsahuje vsrc
rovnou data-uri s QR kódem, takže vygenerovaný obrázek tak není třeba ukládat na server ($qrPlatba->getQRCodeImage()
) - uložení obrázku s QR kódem (
$qrPlatba->saveQRCodeImage()
) - získání data-uri (
$qrPlatba->getDataUri()
) - získání instance objektu QrCode (
$qrPlatba->getQRCodeInstance()
)
QRPlatbu v současné době podporují tyto banky: Air Bank, Česká spořitelna, ČSOB, Equa bank, Era, Fio banka, Komerční banka, mBank, Raiffeisenbank, ZUNO.
Podporuje PHP 8.2+
Instalace pomocí Composeru
composer require "hranicka/qr-platba:^2"
Příklad
<?php require __DIR__ . '/vendor/autoload.php'; use Defr\QRPlatba\QRPlatba; $qrPlatba = new QRPlatba(); $qrPlatba->setAccount('12-3456789012/0100') // nastavení č. účtu ->setIBAN('CZ3112000000198742637541') // nastavení č. účtu ->setVariableSymbol('2016001234') ->setMessage('Toto je první QR platba.') ->setConstantSymbol('0308') ->setSpecificSymbol('1234') ->setAmount('1234.56') ->setCurrency('CZK') // Výchozí je CZK, lze zadat jakýkoli ISO kód měny ->setDueDate(new \DateTime()); echo $qrPlatba->getQRCodeImage(); // Zobrazí <img> tag s kódem, viz níže
Ukázky (viz test/OutputTest.php
), zkuste si je naskenovat v bankovnictví nebo třeba iDokladu jako QR Fakturu:
QR Platba a popisek v EUR (PNG):
QR Platba+F a popisek v EUR (PNG):
Lze použít i jednodušší zápis:
echo QRPlatba::create('12-3456789012/0100', 987.60) ->setMessage('QR platba je parádní!') ->getQRCodeImage();
Pro IBAN pak:
echo QRPlatba::create('CZ6508000000192000145399', 987.60) ->setMessage('QR platba je parádní!') ->getQRCodeImage();
Další možnosti
Uložení do souboru
// Uloží png o velikosti 100x100 px $qrPlatba->saveQRCodeImage("qrcode.png", "png", 100); // Uloží svg o velikosti 100x100 px $qrPlatba->saveQRCodeImage("qrcode.svg", "svg", 100); // Generování jen QR Faktury $qrPlatba->setIsOnlyInvoice(true)->setLabel('QR Faktura');
Aktuální možné formáty jsou:
- PNG
- SVG
Pro další je potřeba dopsat vlastní Writer
Zobrazení data-uri
// data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUAAAAFAAQMAAAD3XjfpAAAA... echo $qrPlatba->getDataUri();
Odkazy
- Oficiální web QR Platby - http://qr-platba.cz/
- Oficiální web QR Faktury - http://qr-faktura.cz/
- Repozitář, který mě inspiroval - https://github.com/snoblucha/QRPlatba
- Fork, ze kterého jsem zpětně přidal a upravil implementaci QR Faktury - https://github.com/bonami/qr-platba
- Image by storyset on Freepik
Contributing
Budu rád za každý návrh na vylepšení ať už formou issue nebo pull requestu.