Free and open-source, QRCGen-API is a simplified version of the typical QRcode generator. Can be used for all purposes. Users simply deploy this app or service on their backend and can immediately consume this API on their frontend
Note
The word "QR Code" is registered trademark of: DENSO WAVE INCORPORATED
POST /api/v1/generate
POST Body Request Attribute (Minimum)
{
"payload": {
"text": "{{$randomString}}",
"output": "base64"
},
"options": {
"type": "png",
"errorCorrectionLevel": "M"
},
"renderOptions": {
"quality": 80
}
}
Props | Key | Descriptions | Required |
---|---|---|---|
payload | text output |
text : key for generating qr code, output : can be file/image or base64file format. valid value (base64 , file ) |
Required |
text |
type: String |
Required | |
segment [readme] |
type: Object of Array |
Optional | |
output |
type: String |
Required | |
options | version |
type: Number |
Optional |
errorCorrectionLevel |
type: String default: M |
Required | |
maskPattern |
type: Any |
Optional | |
scale |
type: Number |
Optional | |
margin |
type: Number default: 4 |
Optional | |
small |
type: Boolean default: False |
Optional | |
color |
consist of 2 key: dark and light area. Both type are String |
Optional | |
width |
type: Number |
Optional | |
type |
type: Any valid: svg and png |
Required | |
renderOptions | quality |
type: Number |
Required |
deflateLEvel |
type: Any |
Optional | |
deflateStrategy |
type: Any |
Optional | |
Both defalateLevel and deflateStrategy only works with PNG type options |
By default, QRCGen will automatically generate the QR Code based on text
value on payload, and this is the preferred way to generate the QR Code.
If auto mode doesn't work for you or you have specific needs, is also possible to manually specify each segment with the relative mode. In this way no segment optimizations will be applied under the hood. Segments list can be passed as an array of object:
{
"payload": {
"segment": [
{ "data": "ABCDE" , "mode": "Alpanumeric" },
{ "data": "12345" , "mode": "Numeric" },
{ "data": "?q1&q2", "mode": "Byte" }
]
}
}
Warning
If you specify text
on payload, then segment
will be an optional key/value and QRCGen will ignore or forbid this value
POST - Generate (Output Type: File)
{
"status": "OK",
"code": 200,
"result": {
"image": "http://www.hostname.app/qrcodes/418cf9c5cde379f121ee.png",
"download_link": "http://www.hostname.app/api/v1/download/418cf9c5cde379f121ee.png"
}
}
POST - Generate (Output Type: dataURL / base64file)
{
"status": "OK",
"code": 200,
"result": {
"base64file": "{{base64-string}}"
}
}
base64 file example
