Base58
Base58は、バイナリデータをASCII
文字にエンコードする方法で、58
文字(1-9、A-Z、a-z、混同しやすい文字 0、O、I、l を除く)を使用してデータを表現します。dongle
は標準およびストリーミングBase58
エンコードをサポートしており、ビットコインスタイルの仕様に従います。
デフォルトのアルファベットは
123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz
です、base58.StdAlphabet
を設定することでアルファベットをカスタマイズできます
データのエンコード
入力データ
go
// 入力文字列
encoder := dongle.Encode.FromString("hello world").ByBase58()
// 入力バイトスライス
encoder := dongle.Encode.FromBytes([]byte("hello world")).ByBase58()
// 入力ファイルストリーム
file, _ := os.Open("test.txt")
encoder := dongle.Encode.FromFile(file).ByBase58()
// エンコードエラーをチェック
if encoder.Error != nil {
fmt.Printf("エンコードエラー: %v\n", encoder.Error)
return
}
出力データ
go
// 出力文字列
encoder.ToString() // StV1DL6CwTryKyV
// 出力バイトスライス
encoder.ToBytes() // []byte("StV1DL6CwTryKyV")
データのデコード
入力データ
go
// 入力文字列
decoder := dongle.Decode.FromString("StV1DL6CwTryKyV").ByBase58()
// 入力バイトスライス
decoder := dongle.Decode.FromBytes([]byte("StV1DL6CwTryKyV")).ByBase58()
// 入力ファイルストリーム
file, _ := os.Open("test.txt")
decoder := dongle.Decode.FromFile(file).ByBase58()
// デコードエラーをチェック
if decoder.Error != nil {
fmt.Printf("デコードエラー: %v\n", decoder.Error)
return
}
出力データ
go
// 出力文字列
decoder.ToString() // hello world
// 出力バイトスライス
decoder.ToBytes() // []byte("hello world")