voucher/internal/pkg/cmb/sm4/sm4_test.go

35 lines
1.0 KiB
Go

package sm4
import (
"encoding/base64"
"testing"
)
func TestECBDecrypt(t *testing.T) {
decode, err := base64.StdEncoding.DecodeString("TfbbYELgZetVpVhhTK31Wg==")
if err != nil {
t.Fatalf("decode error: %v", err)
}
key := []byte{16, 101, 63, 34, 97, 41, 62, 49, 225, 208, 57, 189, 50, 158, 31, 100}
//iv := []byte{34, 244, 188, 11, 120, 236, 119, 58, 191, 210, 3, 95, 85, 72, 172, 249}
plainText, err := ECBDecrypt(key, decode)
if err != nil {
t.Fatalf("ecb decrypt error: %v", err)
}
t.Log("ecb decrypt result:", string(PKCS5UnPadding(plainText)))
}
func TestCFBEncrypt(t *testing.T) {
key := []byte{16, 101, 63, 34, 97, 41, 62, 49, 225, 208, 57, 189, 50, 158, 31, 100}
iv := []byte{34, 244, 188, 11, 120, 236, 119, 58, 191, 210, 3, 95, 85, 72, 172, 249}
decode, err := base64.StdEncoding.DecodeString("XO9I6k9h2zk/dHSK+zo3Dg==")
if err != nil {
t.Fatalf("decode error: %v", err)
}
bytes, err := OFBDecrypt(key, iv, decode)
if err != nil {
t.Fatalf("ecb decrypt error: %v", err)
}
t.Log("ecb decrypt result:", string(PKCS5UnPadding(bytes)))
}