Zobrazení base64 img net::ERR_INVALID_URL
- mimacala
- Člen | 113
Ahojte, už delší dobu bojuji s QR kódy.
Používám z composeru https://qrcode-library.readthedocs.io/en/latest/.
Dle dokumentace používám funkci „$qrCode->writeDataUri()“, která vytvoří kompletní src base64 pro obrázek a poté mi tuto cestu uloží do databáze.
Zde ukládám QR do db
public function handleGenerateQR($idurl): void
{
$urlky = $this->url->ReturnUserUrls($this->user->getIdentity()->email); // uživatele urls
foreach ($urlky as $url)
{
if($url->id == $idurl) // pokud url kterou vlastní přihlášený uživatel
{
$qrCode = $this->qr = (new QrCode($url->shorturl))
->setSize(250)
->setMargin(5)
->setEncoding('UTF-8');
$update = $this->url->UpdateUrls($url->id,["qrcode" => $qrCode->writeDataUri()]);
if($this->url->UpdateUrls($url->id,["qr" => "1"]))
{
$this->flashMessage('qr has been generated', "success");
$this->redirect("this");
} else {
$this->flashMessage('Something went wrong', "error");
$this->redirect("this");
}
}
}
$this->flashMessage('Something went wrong1', "error");
$this->redirect("this", );
}
Zde potom výpis z db zobrazuji v šabloně. Ve zdrojovém kódu to vyhodí
<img src="" />
{foreach $urls as $url}
<tr>
<th scope="row">{$url->longurl}</th>
<td>{$url->shorturl}</td>
<td><img src="{$url->qrcode|nocheck}" /></td>
</tr>
{/foreach}
public function renderQr(int $page = 1)
{
$this->setLayout('User'); // nastaví layout na home
//vrátí url adresy uživatele
$urlky = $this->url->ReturnUserUrls($this->user->getIdentity()->email);
$lastPage = 0;
$this->template->urls = $urlky->page($page,5,$lastPage);
$this->template->page = $page;
$this->template->lastPage = $lastPage;
//vrátí doménu serveru
$this->template->domain = $this->ReturnDomain();
//vrátí brand
$this->template->brand = $this->setting->ReturnBrand();
//vrátí email do šablony
$this->template->name = $this->user->getIdentity()->email;
}
Místo obrázku se ale zobrazuje bílé okénko a v konzoli to vypisuje
net::ERR_INVALID_URL.
S tím to jsem se ještě nesetkal tam moc nevím jak to řešit ?
Generuje knihovna špatně base64 kód ? Je něco špatně při předání do
latte ?
Pokud využiji jinou funkci knihovy třeba pro qr v novém okně, tak
normálně funguje, tedy usuzuji, že v base64 problém nebude.
Moc děkuji za váš čas a případné rady.
- nightfish
- Člen | 519
@mimacala Podle mě jsou ta base64-encoded data příliš krátká na
to, aby obsahovala rozumný PNG soubor. Co jsem si zkoušel pár generátorů QR
kódů pro URL, tak výsledné PNG mělo kolem 2 kB – tvoje má 233 B.
Nemáš náhodou sloupeček v databázi s omezenou velikostí (např.
varchar(255)
)?
- Marek Bartoš
- Nette Blogger | 1280
Dej si tam typ mediumtext a budeš ok :)
Btw, v mysql to číslo v závorce reálně nedělá vůbec nic
důležitého.
- m.brecher
- Generous Backer | 873
@mimacala
Dle dokumentace používám funkci „$qrCode->writeDataUri()“, která vytvoří kompletní src base64 pro obrázek a poté mi tuto cestu uloží do databáze.
Ještě než data kódovaná QR kódem uložíš do databáze je dobré se zamyslet nad tím, kolikrát se tato data budou zobrazovat. QR kódy jsou obvykle použité pro přenos dat z jedné aplikace do druhé přes nějakou čtečku. A při takovémto přenosu je typické jedno jediné čtení na jeden QR kód. Takže třeba vygeneruješ QR kód do faktury a faktura je někam odeslaná. Příjemce si fakturu jednou načte QR čtečkou a dál už se QR kód nepoužívá. V QR kódu jsou typicky kódovaná data uložená v databázi. Uložením QR kódu do databáze se DUPLIKUJÍ databázová data, což je v rozporu s principy normalizace dat. Duplikace má smysl např. z výkonnostních důvodů. Pokud se generování jednoho QR kódu v aplikaci bude pohybovat v řádu jednotek/nižších desítek opakování, tak bych QR kód do databáze vůbec neukládal a rovnou bych ho vykreslil do html.
Já mám třeba aplikaci, kde se na jedné html stránce tiskne cca 50 QR kódů na nálepky. Generuji QR kódy dynamicky rovnou do stránky base64 a běhá to na výbornou.
Editoval m.brecher (21. 6. 2023 16:02)
- Kamil Valenta
- Člen | 822
Marek Bartoš napsal(a):
Btw, v mysql to číslo v závorce reálně nedělá vůbec nic důležitého.
To možná zbytečně trochu klame. Platí to jen do chvíle, než nad tím varcharem bude potřeba index.