package tools import ( "crypto/md5" "crypto/sha256" "encoding/base64" "encoding/hex" "math/rand" "strconv" "strings" "time" ) //md5加密 func Md5(src string) string { m := md5.New() m.Write([]byte(src)) res := hex.EncodeToString(m.Sum(nil)) return res } //Sha256加密 func Sha256(src string) string { m := sha256.New() m.Write([]byte(src)) res := hex.EncodeToString(m.Sum(nil)) return res } func Base64Encode(subject string) string { return base64.StdEncoding.EncodeToString([]byte(subject)) } func Base64Decode2(subject string) ([]byte, error) { return base64.StdEncoding.DecodeString(subject) } func Base64Decode(str string) string { reader := strings.NewReader(str) decoder := base64.NewDecoder(base64.RawStdEncoding, reader) // 以流式解码 buf := make([]byte, 1024) // 保存解码后的数据 dst := "" for { n, err := decoder.Read(buf) dst += string(buf[:n]) if n == 0 || err != nil { break } } return dst } //生成随机数 func RandNum(n int) string { rand.Seed(time.Now().UnixNano()) res := "" for i := 1; i <= n; i++ { res += strconv.Itoa(rand.Intn(10)) } return res }