Skip to content

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")

MITライセンスに基づいて公開されており、許可なく複製することは禁止されています