您好,欢迎来到12图资源库!分享精神,快乐你我!我们只是素材的搬运工!!
  • 首 页
  • 当前位置:首页 > 开发 > WEB开发 >
    Go言语生成二维码是如此复杂
    时间:2020-08-07 21:20 来源:网络整理 作者:网络 浏览:收藏 挑错 推荐 打印

    二维码作为一种快速的输入手腕越来越盛行,支付,添加好友,买东西,扫个二维码就可以,十分方便。那么二维码是如何制造生成的呢?我们如何制造本人的二维码呢?

    Go言语生成二维码是如此复杂

    什么是二维码?

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

    以上节选自维基百科。

    Go言语生成二维码图片

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

    这个库的运用很复杂,假设我要以我的博客网站地址生成一张256*256的图片,可以运用如下代码:

    import "github.com/skip2/go-qrcode" 

    func main() { 

        qrcode.WriteFile("",qrcode.Medium,256,"./blog_qrcode.png"

    这样我们运转代码的时分,就在以后目录下,生成一张256*256的二维码,扫描后可以看到内容是。

    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字节数组,这样我们就可以对这个字节数组停止处置了。

    自定义二维码

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

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

    func main() { 

        qr,err:=qrcode.New("",qrcode.Medium) 

        if err != nil { 

            log.Fatal(err) 

        } else { 

            qr.BackgroundColor = color.RGBA{50,205,50,255} 

            qr.ForegroundColor = color.White 

            qr.WriteFile(256,"./blog_qrcode.png"

        } 

    指定*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的这些字段都是可以设置的,这样我们就可以灵敏自定义二维码了。

    小结

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

    【编辑引荐】

    微信二维码登录原理

    如何用.NET生成二维码?

    如何运用Java、Servlet创立二维码

    PHP生成中间带LOGO图像的二维码

    你了解二维码扫描背后的登录原理吗?

    (责任编辑:admin)