版本加密解密的实现 package lib import ( "fmt" "strconv" ) func Id2Code(id int, version byte) string { var code string = "" if version == '1' { number := id for { remain := number % 10000000 str := Base62Encode(remain) code = str + code number = number / 10000000 if number == 0 { break } } code = string(version) + code } return code } func Code2Id(code string) int { version := code[0] code = code[1:] if version == '1' { var buffer string = "" for i := len(code); i > 0; i -= 4 { start := i - 4 if start < 0 { start = 0 } seg := code[start:i] segId := Base62Decode(seg) // 大于7位非法 if segId >= 100000000 { return 0 } buffer += fmt.Sprintf("%07d", Base62Decode(seg)) } result, _ := strconv.Atoi(buffer) return result } return 0 } Base62加密解密的实现 package lib import ( "math" "bytes" ) const dictLength = 62 var dict []byte = []byte{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'} func Base62Encode(id int) string { result := make([]byte, 0) number := id for number > 0 { round := number / dictLength remain := number % dictLength result = append([]byte{dict[remain]}, result...) number = round } return string(result) } func Base62Decode(code string) int { var result int = 0 codeLength := len(code) for i, c := range []byte(code) { result += bytes.IndexByte(dict, c) * int(math.Pow(dictLength, float64(codeLength - 1 - i))) } return result }
版本加密解密的实现 package lib import ( "fmt" "strconv" ) func Id2Code(id int, version byte) string { var code string = "" if version == '1' { number := id for { remain := number % 10000000 str := Base62Encode(remain) code = str + code number = number / 10000000 if number == 0 { break } } code = string(version) + code } return code } func Code2Id(code string) int { version := code[0] code = code[1:] if version == '1' { var buffer string = "" for i := len(code); i > 0; i -= 4 { start := i - 4 if start < 0 { start = 0 } seg := code[start:i] segId := Base62Decode(seg) // 大于7位非法 if segId >= 100000000 { return 0 } buffer += fmt.Sprintf("%07d", Base62Decode(seg)) } result, _ := strconv.Atoi(buffer) return result } return 0 } Base62加密解密的实现 package lib import ( "math" "bytes" ) const dictLength = 62 var dict []byte = []byte{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'} func Base62Encode(id int) string { result := make([]byte, 0) number := id for number > 0 { round := number / dictLength remain := number % dictLength result = append([]byte{dict[remain]}, result...) number = round } return string(result) } func Base62Decode(code string) int { var result int = 0 codeLength := len(code) for i, c := range []byte(code) { result += bytes.IndexByte(dict, c) * int(math.Pow(dictLength, float64(codeLength - 1 - i))) } return result }