Creating QR codes in Laravel 11 applications can be an easy process with the right packages and setup. In this post, we will walk through how to generate QR codes using the popular simple-qrcode
package, which is a wrapper for the robust BaconQrCode
library. We will cover everything from installation to rendering QR codes in your views.
Prerequisites
Before start, make sure you have Laravel 11 installed on your system. If Laravel 11 is released by the time you read this guide, the methods described here should be applicable for Laravel 8 and later, assuming no major changes to package management or service providers.
Step 1: Install the Simple-QRCode Package to generate QR codes
First, you need to add the QR code package to your Laravel project. Run the following command in your terminal:
composer require simplesoftwareio/simple-qrcode
Step 2: Configuration
With Laravel’s auto-discovery feature, the service provider and facade will automatically be registered. However, if you need to manually register it, you can add the provider and alias to your config/app.php
file:
'providers' => [
SimpleSoftwareIO\QrCode\QrCodeServiceProvider::class,
],
'aliases' => [
'QrCode' => SimpleSoftwareIO\QrCode\Facades\QrCode::class,
],
Step 3: Generating QR Codes
You can generate QR codes directly in your controllers or views. Here’s how you can generate a basic QR code:
In a Controller Method:
use SimpleSoftwareIO\QrCode\Facades\QrCode;
public function generateQRCode()
{
$image = QrCode::size(300)->generate('Embed this content into the QR Code');
return view('qrCode', ['image' => $image]);
}
In a Blade View:
You can directly embed the QR code generation in a Blade template like this:
<div>
{!! QrCode::size(300)->generate('Embed this content into the QR Code') !!}
</div>
Step 4: Advanced Options
The simple-qrcode
package offers various customization options, such as changing the size, color, margin, and adding a logo in the middle of the QR code:
public function generateCustomQRCode()
{
$image = QrCode::format('png')
->size(300)
->color(255, 0, 0)
->backgroundColor(255, 255, 255)
->margin(1)
->merge('/public/path-to-logo.jpg', .3)
->generate('Customize your QR code content here');
return view('customQrCode', ['image' => $image]);
}
Conclusion
Integrating QR code functionality into your Laravel application is straightforward with the simple-qrcode
package. You can use QR codes for a variety of applications such as user authentication, product information, link sharing, and more.
Checkout our other posts about laravel here.
For further customization and advanced features, refer to the official documentation of the simple-qrcode package.