使用Go語言製作二維碼

安全劍客發表於2020-08-16
二維碼作為一種快速的輸入手段越來越流行,支付,新增好友,買東西,掃個二維碼就可以,非常方便。那麼二維碼是如何製作生成的呢?我們如何製作自己的二維碼呢?

使用Go語言製作二維碼使用Go語言製作二維碼

什麼是二維碼?

二維條碼是指在一維條碼的基礎上擴充套件出另一維具有可讀性的條碼,使用黑白矩形圖案表示二進位制資料,被裝置掃描後可獲取其中所包含的資訊。一維條碼的寬度記載著資料,而其長度沒有記載資料。二維條碼的長度、寬度均記載著資料。二維條碼有一維條碼沒有的“定位點”和“容錯機制”。容錯機制在即使沒有辨識到全部的條碼、或是說條碼有汙損時,也可以正確地還原條碼上的資訊。

以上節選自維基百科。

Go語言生成二維碼圖片

使用Go語言程式設計時,生成任意內容的二維碼是非常方便的,因為我們有go-qrcode這個庫。該庫的原始碼託管在github上,大家可以下載使用 。

這個庫的使用很簡單,假如我要以我的部落格網站地址生成一張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函式的原型定義如上,它有幾個引數,大概意思如下:

  1. content表示要生成二維碼的內容,可以是任意字串。
  1. level表示二維碼的容錯級別,取值有Low、Medium、High、Highest。
  1. size表示生成圖片的width和height,畫素單位。
  1. 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(") 
    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可以透過這個庫來生成。

原文地址:

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2712142/,如需轉載,請註明出處,否則將追究法律責任。

相關文章