如何在Go

时间:2017-06-27 07:27:14

标签: go random cryptography

我正在尝试在Go中生成一个具有可变长度的随机整数,但我总是得到填充总长度的数字。这是我的代码:

package main

import (
    "fmt"
    "math/big"
    "crypto/rand"
)

const ResultsPerPage = 30

var (
        total = new(big.Int).SetBytes([]byte{
                0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFE,
                0xBA, 0xAE, 0xDC, 0xE6, 0xAF, 0x48, 0xA0, 0x3B, 0xBF, 0xD2, 0x5E, 0x8C, 0xD0, 0x36, 0x41, 0x40,
        })
        pages = new(big.Int).Div(total, big.NewInt(ResultsPerPage))
        random *big.Int
        err error
)

func main() {

fmt.Println(pages)
fmt.Println(randomString(pages))
}

func randomString(l *big.Int) string {
  random, err = rand.Int(rand.Reader, l)
  fmtrandom := fmt.Sprint(random)
  return string(fmtrandom)
}

输出

3859736307910539847452366166956263595094585475969163479420172104717272049811
3479662380009045046388212253547512051795238437604387552617121977169155584415

代码示例:https://play.golang.org/p/HxAb6Rs_Uj

感谢任何帮助。谢谢。

1 个答案:

答案 0 :(得分:2)

如果我理解正确,您遇到的问题是随机数似乎总是与最大允许值具有相同的位数,对吧?当我运行代码时,情况并非如此。这是我刚刚观察到的输出:

3859736307910539847452366166956263595094585475969163479420172104717272049811
65719900872761032562423535702578352960653752260368991759410130265294153783

在操场上,我相信随机的种子和时钟时间是固定的,所以你会反复看到相同的结果。但是在本地运行时,我看到了输出长度的预期变化。

<强>更新

您可能想知道为什么您可以多次运行此代码并观察随机数​​的长度通常接近最大值的长度。

一点点数学解释了这个。让我们想象一下,我们会选择0到999之间的数字。该范围内有多少个数字:

  1. 3位数? 900(100-999)
  2. 2位数? 90(10-99)
  3. 1位数? 10(0-9)
  4. 同样,使用非常大的最大值,可以拾取的大多数数字将非常接近最大长度。很难看到短于该长度的两位数字。 (您应该在1%的时间内看到它们。)