Loading... > 本文由 [简悦 SimpRead](http://ksria.com/simpread/) 转码, 原文地址 [c.biancheng.net](http://c.biancheng.net/view/vip_7341.html) > 二维码作为一种快速的输入手段越来越流行,支付,添加好友,买东西,扫个二维码即可,可以说二维码已经深深地融入了我们的生活中。那么二维码是如何制作生成的呢?我们如何制 二维码作为一种快速的输入手段越来越流行,支付,添加好友,买东西,扫个二维码即可,可以说二维码已经深深地融入了我们的生活中。那么二维码是如何制作生成的呢?我们如何制作自己的二维码呢? 什么是二维码? -------------- 二维条码是指在一维条码的基础上扩展出另一维具有可读性的条码,使用黑白矩形图案表示二进制数据,被设备扫描后可获取其中所包含的信息。一维条码的宽度记载着数据,但其长度没有记载数据,而二维条码的长度、宽度均记载着数据。 二维条码有一维条码没有的 “定位点” 和“容错机制”,容错机制在即使没有辨识到全部的条码、或是说条码有污损时,也可以正确地还原条码上的信息。 使用 Go 语言生成二维码图片 -------------------------- 使用 Go 语言编程时,生成任意内容的二维码是非常方便的,因为我们有 go-qrcode 这个库。该库的源代码托管在 github 上,大家可以从 github 上( [https://github.com/skip2/go-qrcode](https://github.com/skip2/go-qrcode) )下载并使用这个库。 go-qrcode 的使用很简单,假如要为我们的官网 [http://c.biancheng.net/](http://c.biancheng.net/) 生成一张 256*256 的图片,可以使用如下代码: ``` package main import "github.com/skip2/go-qrcode" func main() { qrcode.WriteFile("http://c.biancheng.net/",qrcode.Medium,256,"./golang_qrcode.png") } ``` ``` package main import( "github.com/skip2/go-qrcode" "image/color" "log" ) func main() { qr,err:=qrcode.New("http://c.biancheng.net/",qrcode.Medium) if err != nil { log.Fatal(err) } else { qr.BackgroundColor = color.RGBA{50,205,50,255} qr.ForegroundColor = color.White qr.WriteFile(256,"./golang_qrcode.png") } } ``` ``` 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 } ``` 这样我们运行代码的时候,就在当前目录下,生成一张 256*256 的二维码,扫描后就可以自动跳转到我们的官网,如下所示: ![](http://c.biancheng.net/uploads/allimg/191217/4-19121G053004M.gif) 图:二维码 func WriteFile(content string, level RecoveryLevel, size int, filename string) error WriteFile 函数的原型定义如上,它有几个参数,大概意思如下: * content 表示要生成二维码的内容,可以是任意字符串; * level 表示二维码的容错级别,取值有 Low、Medium、High、Highest; * size 表示生成图片的 width 和 height,像素单位; * 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 字节数组,这样我们就可以对这个字节数组进行处理了。 自定义二维码 ------------ 除了以上两种快捷方式,go-qrcode 库还为我们提供了对二维码的自定义方式,比如我们可以自定义二维码的前景色和背景色等。qrcode.New 函数可以返回一个 *QRCode,我们可以对 *QRCode 设置,实现对二维码的自定义。 比如我们设置背景色为绿色,前景色为白色的二维码 ``` 复制纯文本复制 ``` ``` package main import( "github.com/skip2/go-qrcode" "image/color" "log")func main() { qr,err:=qrcode.New("http://c.biancheng.net/",qrcode.Medium) if err != nil { log.Fatal(err) } else { qr.BackgroundColor = color.RGBA{50,205,50,255} qr.ForegroundColor = color.White qr.WriteFile(256,"./golang_qrcode.png") }} ``` ``` package main import( "github.com/skip2/go-qrcode" "image/color" "log" ) func main() { qr,err:=qrcode.New("http://c.biancheng.net/",qrcode.Medium) if err != nil { log.Fatal(err) } else { qr.BackgroundColor = color.RGBA{50,205,50,255} qr.ForegroundColor = color.White qr.WriteFile(256,"./golang_qrcode.png") } } ``` 指定 *QRCode 的 BackgroundColor 和 ForegroundColor 即可,然后调用 WriteFile 方法生成这个二维码文件,如下所示: ![](http://c.biancheng.net/uploads/allimg/191217/4-19121G05319218.gif) 图:二维码 ``` 复制纯文本复制 ``` ``` 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} ``` ``` 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 的这些字段都是可以设置的,这样我们就可以灵活自定义二维码了。 小结:二维码是一种流行的输入技术手段,不光 Go 可以生成,其他语言也可以生成,并且生成的二维码是标准的,都可以扫描和识别,比如 Java 可以通过 https://github.com/kenglxn/QRGen 库来生成。 最后修改:2023 年 07 月 25 日 © 允许规范转载 打赏 赞赏作者 支付宝微信 赞 如果觉得我的文章对你有用,请随意赞赏