以前写过一篇用java语言实现二维码,今天看到了用go语言实现二维码,发现简单了很多。

go语言实现二维码

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

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

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

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

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

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

type RecoveryLevel int

const (
    // Level L: 7% error recovery.
    Low RecoveryLevel = iota

    // Level M: 15% error recovery. Good default choice.
    Medium    
    // Level Q: 25% error recovery.
    High    
    // Level H: 30% error recovery.
    Highest
)

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

生成二维码字节

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

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

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

自定义二维码

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

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

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

func New(content string, level RecoveryLevel) (*QRCode, error)

// A QRCode represents a valid encoded QRCode.
type QRCode struct {
    // Original content encoded.
    Content string

    // QR Code type.
    Level         RecoveryLevel
    VersionNumber int

    // User settable drawing options.
    ForegroundColor color.Color
    BackgroundColor color.Color
}

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