假設我想使用以下方法生成 0 到 27 之間的安全隨機整數:func Int(rand io.Reader, max *big.Int) (n *big.Int, err error)在"crypto/rand"包中。我該怎么做?我真的不明白這是如何工作的,為什么它不返回一個內置的 Go ints 而不是指向某個 big.Int 類型的指針?編輯:這對于令牌來說是否足夠安全?func getToken(length int) string { token := "" codeAlphabet := "ABCDEFGHIJKLMNOPQRSTUVWXYZ" codeAlphabet += "abcdefghijklmnopqrstuvwxyz" codeAlphabet += "0123456789" for i := 0; i < length; i++ { token += string(codeAlphabet[cryptoRandSecure(int64(len(codeAlphabet)))]) } return token}func cryptoRandSecure(max int64) int64 { nBig, err := rand.Int(rand.Reader, big.NewInt(max)) if err != nil { log.Println(err) } return nBig.Int64()}func main() { fmt.Println(getToken(32))}這將輸出如下內容:qZDbuPwNQGrgVmZCU9A7FUWbp8eIfn0ZEwZVoQ5D5SEfdhiRsDfH6dU6tAovILCZcOqzODVP0GwbiNBwtmqLA78rFgV9d3VT
- 3 回答
- 0 關注
- 402 瀏覽
添加回答
舉報
0/150
提交
取消