"crypto/rand.Int"를 사용한 무작위 Int 생성
"crypto/rand" 패키지 내에는 안전한 무작위 생성이 필요합니다. 정수. 0~27 범위에서 이를 달성하는 방법의 예는 다음과 같습니다.
package main import ( "crypto/rand" "fmt" "math/big" ) func main() { nBig, err := rand.Int(rand.Reader, big.NewInt(27)) if err != nil { panic(err) } n := nBig.Int64() fmt.Printf("Random int in [0,27): %d\n", n) }
이 함수는 "math/big" 라이브러리의 "rand.Reader" 및 "big.Int" 유형을 활용합니다. int 범위를 넘어서는 암호화 무작위성을 달성합니다.
보안 토큰 생성
그러나 보안 토큰을 생성하는 맥락에서는 보다 적절한 대체 접근 방식이 권장됩니다.
package main import ( "crypto/rand" "encoding/base32" "fmt" ) func main() { token := getToken(10) fmt.Printf("Secure token: %s\n", token) } func getToken(length int) string { randomBytes := make([]byte, 32) _, err := rand.Read(randomBytes) if err != nil { panic(err) } return base32.StdEncoding.EncodeToString(randomBytes)[:length] }
이 시나리오에서는 임의 바이트가 생성된 다음 다음을 사용하여 인코딩됩니다. 토큰을 생성하려면 "base32"를 사용하세요. 이 접근 방식은 보안 토큰 생성에 충분한 것으로 간주됩니다.
위 내용은 'crypto/rand'를 사용하여 안전한 무작위 정수 및 토큰을 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!