"crypto/rand" 패키지를 사용하여 안전한 임의 정수 생성
"crypto/rand" 패키지를 사용하여 0에서 27 사이의 임의 정수를 안전하게 생성하려면 /rand" 패키지에서 다음 함수를 활용할 수 있습니다.
func Int(rand io.Reader, max *big.Int) (n *big.Int, err error)
이 함수는 무작위로 생성된 정수를 나타내는 big.Int에 대한 포인터를 반환하며 io.Reader(이 경우 rand)를 사용합니다. .Reader) 및 최대값을 지정하는 big.Int.
이 함수를 사용하여 0에서 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) }
"crypto/rand" 패키지는 임의 정밀도 정수를 나타내기 위해 big.Int 유형을 사용하기 때문에 go 정수를 직접 수신합니다. 이는 다양한 시나리오에 더 유연합니다.
보안 토큰을 생성하려면 비슷한 방법을 사용할 수 있습니다. 임의의 바이트 배열을 생성하고 이를 적절한 인코딩 체계(예: Base64 또는 Base32)를 사용하여 인코딩하여 바이트를 토큰 문자열로 변환하는 방식으로 접근합니다.
예를 들어 제공하신 코드 조각(getToken)은 이 접근 방식을 사용하여 보안 토큰을 생성하는 방법을 보여줍니다.
위 내용은 'crypto/rand' 패키지를 사용하여 안전한 무작위 정수를 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!