本文整理匯總了Golang中crypto/rand.Prime函數的典型用法代碼示例。如果您正苦於以下問題:Golang Prime函數的具體用法?Golang Prime怎麽用?Golang Prime使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Prime函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: genModuli
func genModuli(numModuli int, output chan<- *big.Int, wg *sync.WaitGroup) {
dupChan := make(chan *big.Int, 1)
var prime1, prime2 *big.Int
var err error
for i := 0; i < numModuli; i++ {
prime1, err = cryptorand.Prime(cryptorand.Reader, (*bits+1)/2)
if err != nil {
log.Fatal("Unable to generate random prime")
}
if (i % (*dupeprob)) == 1 {
select {
case prime2 = <-dupChan:
output <- new(big.Int).Mul(prime1, prime2)
continue
default:
dupChan <- prime1
}
}
prime2, err = cryptorand.Prime(cryptorand.Reader, (*bits)/2)
if err != nil {
log.Fatal("Unable to generate random prime")
}
output <- new(big.Int).Mul(prime1, prime2)
}
wg.Done()
}
示例2: NewPaillierPrivateKey
// NewPaillierPrivateKey generates a new Paillier private key (key pair).
//
// The key used in the Paillier crypto system consists of four integer
// values. The public key has two parameters; the private key has three
// parameters (one parameter is shared between the keys). As in RSA it
// starts with two random primes 'p' and 'q'; the public key parameter
// are computed as:
//
// n := p * q
// g := random number from interval [0,n^2[
//
// The private key parameters are computed as:
//
// n := p * q
// l := lcm (p-1,q-1)
// u := (((g^l mod n^2)-1)/n) ^-1 mod n
//
// N.B. The division by n is integer based and rounds toward zero!
func NewPaillierPrivateKey(bits int) (key *PaillierPrivateKey, err error) {
// generate primes 'p' and 'q' and their factor 'n'
// repeat until the requested factor bitsize is reached
var p, q, n *big.Int
for {
bitsP := (bits - 5) / 2
bitsQ := bits - bitsP
p, err = rand.Prime(rand.Reader, bitsP)
if err != nil {
return nil, err
}
q, err = rand.Prime(rand.Reader, bitsQ)
if err != nil {
return nil, err
}
n = new(big.Int).Mul(p, q)
if n.BitLen() == bits {
break
}
}
// initialize variables
one := big.NewInt(1)
n2 := new(big.Int).Mul(n, n)
// compute public key parameter 'g' (generator)
g, err := rand.Int(rand.Reader, n2)
if err != nil {
return nil, err
}
// compute private key parameters
p1 := new(big.Int).Sub(p, one)
q1 := new(big.Int).Sub(q, one)
l := new(big.Int).Mul(q1, p1)
l.Div(l, new(big.Int).GCD(nil, nil, p1, q1))
a := new(big.Int).Exp(g, l, n2)
a.Sub(a, one)
a.Div(a, n)
u := new(big.Int).ModInverse(a, n)
// return key pair
pubkey := &PaillierPublicKey{
N: n,
G: g,
}
prvkey := &PaillierPrivateKey{
PaillierPublicKey: pubkey,
L: l,
U: u,
P: p,
Q: q,
}
return prvkey, nil
}
示例3: GeneratePrime
// GeneratePrime randomly generates a big.Int prime number with the given size
// in bits
func GeneratePrime(size int) *big.Int {
prime, err := rand.Prime(rand.Reader, size)
if err != nil {
panic(err)
}
return prime
}
示例4: main
func main() {
end = make(map[int64]int)
b := big.NewInt(int64(10))
for i := 0; i < size; i++ {
r, _ := c_rand.Int(c_rand.Reader, b)
m := r.Int64()
end[m]++
}
for i, j := range end {
fmt.Print(i)
for m := 0; m < j/(size/100); m++ {
fmt.Print("*")
}
fmt.Println(" ", j)
}
for i := 0; i < 11; i++ {
fmt.Println(c_rand.Prime(c_rand.Reader, 64))
}
for i := 0; i < 11; i++ {
fmt.Println(m_rand.ExpFloat64())
}
}
示例5: genState
// genState generates a starting state using Go's 'crypto/rand'
// package. The state will be a 64-bit prime. It'll panic if
// rand.Prime returns an error.
func genState() uint64 {
prime, err := rand.Prime(rand.Reader, 64)
if err != nil {
panic(err)
}
return prime.Uint64()
}
示例6: NewSwizzle
//NewSwizzle makes a Swizzle instance.
func NewSwizzle(key []byte, sectors int, prime *big.Int, primebits int) (Heartbeat, error) {
if key == nil {
key = make([]byte, 32)
rand.Read(key)
}
if primebits <= 0 {
primebits = defaultPrimebits
}
if sectors <= 0 {
sectors = defaultSectors
}
if prime == nil {
var err error
prime, err = rand.Prime(rand.Reader, primebits)
if err != nil {
return nil, err
}
}
m := Swizzle{key: key, prime: prime, sectors: sectors}
m.fKey = make([]byte, 32)
rand.Read(m.fKey)
m.alphaKey = make([]byte, 32)
rand.Read(m.alphaKey)
return &m, nil
}
示例7: New
// Generate a new cyclic group and generator of given bits size.
func New(random io.Reader, bits int) (*Group, error) {
for {
// Generate a large prime of size 'bits'-1
q, err := rand.Prime(random, bits-1)
if err != nil {
return nil, err
}
// Calculate the safe prime p=2q+1 of order 'bits'
p := new(big.Int).Mul(q, big.NewInt(2))
p = new(big.Int).Add(p, big.NewInt(1))
// Probability of p being non-prime is negligible
if p.ProbablyPrime(negligibleExp / 2) {
for {
// Generate a generator of p
a, err := rand.Int(random, p)
if err != nil {
return nil, err
}
// Ensure generator order is not 2 (efficiency)
if b := new(big.Int).Exp(a, big.NewInt(2), p); b.Cmp(big.NewInt(1)) == 0 {
continue
}
// Return if generator order is q
if b := new(big.Int).Exp(a, q, p); b.Cmp(big.NewInt(1)) == 0 {
return &Group{p, a}, nil
}
}
}
}
}
示例8: NewV1
func NewV1(node net.HardwareAddr) (uuid *Uuid, err error) {
var (
inter *net.Interface
t int64
clk *big.Int
clkB []byte
)
v1mutex.Lock()
defer v1mutex.Unlock()
uuid = new(Uuid)
if node == nil {
if inter, err = GetFirstNetInterface(); err == nil {
uuid.Node = inter.HardwareAddr[0:6]
} else if err == errNoInterface {
if uuid.Node, err = GetRandomNode(); err != nil {
return nil, err
}
} else {
return nil, err
}
} else {
uuid.Node = node[0:6]
}
if clk, err = rand.Prime(rand.Reader, 14); err != nil {
return nil, err
}
t = GetTime()
uuid.TimeLow = []byte{
byte(t >> 24),
byte(t >> 16),
byte(t >> 8),
byte(t),
}
uuid.TimeMid = []byte{
byte(t >> 40),
byte(t >> 32),
}
uuid.TimeHiVer = []byte{
byte(t>>56) | ver1,
byte(t >> 48),
}
clkB = clk.Bytes()
uuid.ClockSeq = []byte{
clkB[0] | variant,
clkB[1],
}
return uuid, err
}
示例9: NewMersennePrime
// NewMersennePrime returns a seeded, initialized MT19937, seeded
// using a large from from 'crypto/rand'.
// Will panic if rand.Prime returns an error.
func NewMersennePrime() *MT19937 {
m := New()
prime, err := rand.Prime(rand.Reader, 64)
if err != nil {
panic(err)
}
m.Seed(prime.Int64())
return m
}
示例10: ShowPrime
func ShowPrime() {
for i := 0; i < *iterations; i++ {
if p, err := rand.Prime(rand.Reader, *bits); err != nil {
log.Fatalf("failed to read random prime: %s", err)
} else {
log.Printf("got random prime: %s", p)
}
}
}
示例11: GetRandomNode
func GetRandomNode() (node []byte, err error) {
var bi *big.Int
if bi, err = rand.Prime(rand.Reader, 48); err != nil {
return nil, err
}
return bi.Bytes(), nil
}
示例12: GenerateMultiPrimeKey
// GenerateMultiPrimeKey generates a multi-prime RSA keypair of the given bit
// size, as suggested in [1]. Although the public keys are compatible
// (actually, indistinguishable) from the 2-prime case, the private keys are
// not. Thus it may not be possible to export multi-prime private keys in
// certain formats or to subsequently import them into other code.
//
// Table 1 in [2] suggests maximum numbers of primes for a given size.
//
// [1] US patent 4405829 (1972, expired)
// [2] http://www.cacr.math.uwaterloo.ca/techreports/2006/cacr2006-16.pdf
func GenerateMultiPrimeKey(random io.Reader, nprimes int, bits int) (priv *PrivateKey, err error) {
priv = new(PrivateKey)
priv.E = 65537
if nprimes < 2 {
return nil, errors.New("crypto/rsa: GenerateMultiPrimeKey: nprimes must be >= 2")
}
primes := make([]*big.Int, nprimes)
NextSetOfPrimes:
for {
todo := bits
for i := 0; i < nprimes; i++ {
primes[i], err = rand.Prime(random, todo/(nprimes-i))
if err != nil {
return nil, err
}
todo -= primes[i].BitLen()
}
// Make sure that primes is pairwise unequal.
for i, prime := range primes {
for j := 0; j < i; j++ {
if prime.Cmp(primes[j]) == 0 {
continue NextSetOfPrimes
}
}
}
n := new(big.Int).Set(bigOne)
totient := new(big.Int).Set(bigOne)
pminus1 := new(big.Int)
for _, prime := range primes {
n.Mul(n, prime)
pminus1.Sub(prime, bigOne)
totient.Mul(totient, pminus1)
}
g := new(big.Int)
priv.D = new(big.Int)
y := new(big.Int)
e := big.NewInt(int64(priv.E))
g.GCD(priv.D, y, e, totient)
if g.Cmp(bigOne) == 0 {
priv.D.Add(priv.D, totient)
priv.Primes = primes
priv.N = n
break
}
}
priv.Precompute()
return
}
示例13: newStore
func newStore() *sessions.CookieStore {
storeSeed, err := rand.Prime(rand.Reader, 128)
if err != nil {
fmt.Errorf("Could not initialise CookieStore: %v\n", err)
}
store := sessions.NewCookieStore([]byte(storeSeed.String()))
store.MaxAge(86400) // 1 day
return store
}
示例14: Warmup
// Warmup warms up the PRNG by running a 64-bit prime number of iterations.
func (m *MT19937) Warmup() {
prime, err := rand.Prime(rand.Reader, 64)
if err != nil {
panic(err)
}
n := prime.Uint64()
for i := uint64(0); i < n; i++ {
m.Int64()
}
}
示例15: TestPrimeSmall
// https://golang.org/issue/6849.
func TestPrimeSmall(t *testing.T) {
for n := 2; n < 10; n++ {
p, err := rand.Prime(rand.Reader, n)
if err != nil {
t.Fatalf("Can't generate %d-bit prime: %v", n, err)
}
if p.BitLen() != n {
t.Fatalf("%v is not %d-bit", p, n)
}
if !p.ProbablyPrime(32) {
t.Fatalf("%v is not prime", p)
}
}
}