>백엔드 개발 >Golang >'crypto/rand'를 사용하여 안전한 무작위 정수 및 토큰을 생성하는 방법은 무엇입니까?

'crypto/rand'를 사용하여 안전한 무작위 정수 및 토큰을 생성하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-23 09:09:17984검색

How to Generate Secure Random Integers and Tokens Using

"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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.