添加测试文件

This commit is contained in:
Yun
2025-11-09 18:23:08 +08:00
parent 7bbd570de9
commit 034315ddbd
5 changed files with 93 additions and 10 deletions
+9 -8
View File
@@ -3,11 +3,11 @@ package base64x
import "encoding/base64"
// 普通的
func Base64StdEncode(s string) string {
func StdEncode(s string) string {
return base64.StdEncoding.EncodeToString([]byte(s))
}
func Base64StdDecode(sEnc string) (string, error) {
func StdDecode(sEnc string) (string, error) {
sDec, err := base64.StdEncoding.DecodeString(sEnc)
if err != nil {
return "", err
@@ -16,11 +16,11 @@ func Base64StdDecode(sEnc string) (string, error) {
}
// URL和文件名安全的
func Base64UrlEncode(s string) string {
func UrlEncode(s string) string {
return base64.URLEncoding.EncodeToString([]byte(s))
}
func Base64UrlDecode(sEnc string) (string, error) {
func UrlDecode(sEnc string) (string, error) {
sDec, err := base64.URLEncoding.DecodeString(sEnc)
if err != nil {
return "", err
@@ -29,11 +29,11 @@ func Base64UrlDecode(sEnc string) (string, error) {
}
// 无填充
func Base64RawEncode(s string) string {
func RawEncode(s string) string {
return base64.RawStdEncoding.EncodeToString([]byte(s))
}
func Base64RawDecode(sEnc string) (string, error) {
func RawDecode(sEnc string) (string, error) {
sDec, err := base64.RawStdEncoding.DecodeString(sEnc)
if err != nil {
return "", err
@@ -41,11 +41,12 @@ func Base64RawDecode(sEnc string) (string, error) {
return string(sDec), nil
}
func Base64RawUrlEncode(s string) string {
// URL和文件名安全的,无填充
func RawUrlEncode(s string) string {
return base64.RawURLEncoding.EncodeToString([]byte(s))
}
func Base64RawUrlDecode(s string) (string, error) {
func RawUrlDecode(s string) (string, error) {
decoded, err := base64.RawURLEncoding.DecodeString(s)
return string(decoded), err
}
+43
View File
@@ -0,0 +1,43 @@
package base64x_test
import (
"testing"
"code.yun.ink/pkg/encryptx/base64x"
)
func TestBase64xStd(t *testing.T) {
original := "Hello, World!"
encoded := base64x.StdEncode(original)
decoded, err := base64x.StdDecode(encoded)
if err != nil {
t.Error(err)
}
if original != decoded {
t.Errorf("expected %q, got %q", original, decoded)
}
}
func TestBase64xUrl(t *testing.T) {
original := "Hello, World!"
encoded := base64x.UrlEncode(original)
decoded, err := base64x.UrlDecode(encoded)
if err != nil {
t.Error(err)
}
if original != decoded {
t.Errorf("expected %q, got %q", original, decoded)
}
}
func TestBase64xRaw(t *testing.T) {
original := "Hello, World!"
encoded := base64x.RawEncode(original)
decoded, err := base64x.RawDecode(encoded)
if err != nil {
t.Error(err)
}
if original != decoded {
t.Errorf("expected %q, got %q", original, decoded)
}
}
+19
View File
@@ -0,0 +1,19 @@
package bcryptx
import "golang.org/x/crypto/bcrypt"
// HashPassword 使用 bcrypt 算法对密码进行哈希处理
func HashPassword(password string) (string, error) {
// 第二个参数是 cost 值,代表计算强度
bytes, err := bcrypt.GenerateFromPassword([]byte(password), bcrypt.DefaultCost)
if err != nil {
return "", err
}
return string(bytes), nil
}
// CheckPasswordHash 检查密码是否与哈希值匹配
func CheckPasswordHash(password, hash string) bool {
err := bcrypt.CompareHashAndPassword([]byte(hash), []byte(password))
return err == nil
}
+20
View File
@@ -0,0 +1,20 @@
package bcryptx_test
import (
"testing"
"code.yun.ink/pkg/encryptx/bcryptx"
)
func TestDecryptBcrypt(t *testing.T) {
str, err := bcryptx.HashPassword("password")
if err != nil {
t.Error(err)
}
t.Log(str)
if bcryptx.CheckPasswordHash("password", str) {
t.Log("ok")
} else {
t.Error("error")
}
}
+2 -2
View File
@@ -200,7 +200,7 @@ func Encrypt(encryptType EncryptType, data string, key string, options map[strin
// 编码
case BASE64:
return base64x.Base64StdEncode(data), nil
return base64x.StdEncode(data), nil
default:
return "", fmt.Errorf("不支持的加密类型: %d", encryptType)
@@ -267,7 +267,7 @@ func Decrypt(encryptType EncryptType, data string, key string, options map[strin
// 编码
case BASE64:
return base64x.Base64StdDecode(data)
return base64x.StdDecode(data)
default:
return "", fmt.Errorf("不支持的加密类型: %d", encryptType)