Menjana Integer Rawak Selamat dengan Pakej "crypto/rand"
Untuk menjana integer rawak dengan selamat antara 0 dan 27 menggunakan "crypto /rand", anda boleh menggunakan fungsi berikut:
func Int(rand io.Reader, max *big.Int) (n *big.Int, err error)
Ini fungsi mengembalikan penunjuk kepada big.Int yang mewakili integer yang dijana secara rawak, dan ia memerlukan io.Reader (dalam kes ini rand.Reader) dan big.Int yang menentukan nilai maksimum.
Begini caranya anda boleh menggunakan fungsi ini untuk menjana integer rawak antara 0 dan 27:
package main import ( "fmt" "crypto/rand" "math/big" ) func main() { nBig, err := rand.Int(rand.Reader, big.NewInt(27)) if err != nil { panic(err) } n := nBig.Int64() fmt.Printf("Here is a random int in [0,27): %d\n", n) }
Anda tidak menerima percubaan secara langsung integer kerana pakej "crypto/rand" menggunakan jenis besar.Int untuk mewakili integer ketepatan arbitrari, yang lebih fleksibel untuk pelbagai senario.
Untuk menjana token selamat, anda boleh menggunakan pendekatan yang serupa dengan menjana tatasusunan rawak bait dan pengekodannya menggunakan skema pengekodan yang sesuai (seperti Base64 atau Base32) untuk menterjemah bait kepada rentetan token.
Sebagai contoh, coretan kod yang anda berikan (getToken) menunjukkan cara menjana token selamat menggunakan pendekatan ini.
Atas ialah kandungan terperinci Bagaimana untuk Menjana Integer Rawak Selamat dengan Pakej 'crypto/rand'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!