Go语言生成二维码是如此简单

开发 前端
二维码作为一种快速的输入手段越来越流行,支付,添加好友,买东西,扫个二维码就可以,非常方便。那么二维码是如何制作生成的呢?我们如何制作自己的二维码呢?

二维码作为一种快速的输入手段越来越流行,支付,添加好友,买东西,扫个二维码就可以,非常方便。那么二维码是如何制作生成的呢?我们如何制作自己的二维码呢?

[[336703]]

什么是二维码?

二维条码是指在一维条码的基础上扩展出另一维具有可读性的条码,使用黑白矩形图案表示二进制数据,被设备扫描后可获取其中所包含的信息。一维条码的宽度记载着数据,而其长度没有记载数据。二维条码的长度、宽度均记载着数据。二维条码有一维条码没有的“定位点”和“容错机制”。容错机制在即使没有辨识到全部的条码、或是说条码有污损时,也可以正确地还原条码上的信息。

以上节选自维基百科。

Go语言生成二维码图片

使用Go语言编程时,生成任意内容的二维码是非常方便的,因为我们有go-qrcode这个库。该库的源代码托管在github上,大家可以下载使用 https://github.com/skip2/go-qrcode。

这个库的使用很简单,假如我要以我的博客网站地址http://www.flysnow.org生成一张256*256的图片,可以使用如下代码:

  1. import "github.com/skip2/go-qrcode" 
  2. func main() { 
  3.     qrcode.WriteFile("http://www.flysnow.org/",qrcode.Medium,256,"./blog_qrcode.png"

这样我们运行代码的时候,就在当前目录下,生成一张256*256的二维码,扫描后可以看到内容是http://www.flysnow.org/。

  1. func WriteFile(content string, level RecoveryLevel, size int, filename string) error 

WriteFile函数的原型定义如上,它有几个参数,大概意思如下:

  • content表示要生成二维码的内容,可以是任意字符串。
  • level表示二维码的容错级别,取值有Low、Medium、High、Highest。
  • size表示生成图片的width和height,像素单位。
  • filename表示生成的文件名路径。

RecoveryLevel类型其实是个int,它的定义和常量如下。

  1. type RecoveryLevel int 
  2.  
  3. const ( 
  4.     // Level L: 7% error recovery. 
  5.     Low RecoveryLevel = iota 
  6.  
  7.     // Level M: 15% error recovery. Good default choice. 
  8.     Medium     
  9.     // Level Q: 25% error recovery. 
  10.     High     
  11.     // Level H: 30% error recovery. 
  12.     Highest 

RecoveryLevel越高,二维码的容错能力越好。

生成二维码图片字节

有时候我们不想直接生成一个PNG文件存储,我们想对PNG图片做一些处理,比如缩放了,旋转了,或者网络传输了等,基于此,我们可以使用Encode函数,生成一个PNG 图片的字节流,这样我们就可以进行各种处理了。

  1. func Encode(content string, level RecoveryLevel, size int) ([]byte, error) 

用法和WriteFile函数差不多,只不过返回的是一个[]byte字节数组,这样我们就可以对这个字节数组进行处理了。

自定义二维码

除了以上两种快捷方式,该库还为我们提供了对二维码的自定义方式,比如我们可以自定义二维码的前景色和背景色等。qrcode.New函数可以返回一个*QRCode,我们可以对*QRCode设置,实现对二维码的自定义。

比如我们设置背景色为绿色,前景色为白色的二维码

  1. func main() { 
  2.     qr,err:=qrcode.New("http://www.flysnow.org/",qrcode.Medium) 
  3.     if err != nil { 
  4.         log.Fatal(err) 
  5.     } else { 
  6.         qr.BackgroundColor = color.RGBA{50,205,50,255} 
  7.         qr.ForegroundColor = color.White 
  8.         qr.WriteFile(256,"./blog_qrcode.png"
  9.     } 

指定*QRCode的BackgroundColor和ForegroundColor即可。然后调用WriteFile方法生成这个二维码文件。

  1. func New(content string, level RecoveryLevel) (*QRCode, error) 
  2.  
  3. // A QRCode represents a valid encoded QRCode.type QRCode struct { 
  4.     // Original content encoded. 
  5.     Content string 
  6.  
  7.     // QR Code type. 
  8.     Level         RecoveryLevel 
  9.     VersionNumber int 
  10.  
  11.     // User settable drawing options. 
  12.     ForegroundColor color.Color 
  13.     BackgroundColor color.Color 

以上QRCode的这些字段都是可以设置的,这样我们就可以灵活自定义二维码了。

小结

二维码是一种流行的输入技术手段,不光Go可以生成,其他语言也可以生成,并且生成的二维码是标准的,都可以扫描和识别,比如Java可以通过这个https://github.com/kenglxn/QRGen库来生成。

责任编辑:未丽燕 来源: 飞雪无情
相关推荐

2023-10-31 08:16:16

Go语言二维码

2023-11-17 09:07:51

.NET生成二维码识别二维码

2023-11-17 15:44:06

C++库生成二维码

2015-09-24 09:56:19

.NET二维码

2013-01-30 12:16:49

二维码NFC近场通讯

2013-10-29 09:46:05

二维码

2013-03-27 16:13:17

Android开发Android二维码生QR生成

2014-12-31 15:37:16

二维码生成扫描

2021-02-08 08:40:00

Zint二维码开源

2017-02-21 09:17:46

二维码漏洞

2011-12-06 16:40:45

二维码快拍二维码灵动快拍

2011-08-24 17:58:01

QRals二维码

2017-11-21 09:00:15

PHP二维码LOGO图像

2012-04-01 09:53:13

二维码

2014-03-05 14:41:55

二维码登录

2023-12-25 14:53:36

2015-10-28 13:33:50

二维码条形码扫描源码

2020-10-08 18:48:02

二维码安全应用安全网络攻击

2011-11-24 16:00:23

信息图QR码二维码

2023-08-08 14:16:07

二维码开发鸿蒙
点赞
收藏

51CTO技术栈公众号