Ruby 2.4

SecureRandom

module SecureRandom

安全的随机数发生器接口。

该库是一个安全的随机数生成器的接口,适用于在HTTP Cookie中生成会话密钥等。

您可以通过以下方式在应用程序中使用此库:

require 'securerandom'

它支持以下安全随机数发生器:

  • OpenSSL

  • /dev/urandom

  • Win32

例子

生成随机的十六进制字符串:

require 'securerandom' p SecureRandom.hex(10) #=> "52750b30ffbc7de3b362" p SecureRandom.hex(10) #=> "92b15d6c8dc4beb5f559" p SecureRandom.hex(13) #=> "39b290146bea6ce975c37cfc23"

生成随机base64字符串:

p SecureRandom.base64(10) #=> "EcmTPZwWRAozdA==" p SecureRandom.base64(10) #=> "KO1nIU+p9DKxGg==" p SecureRandom.base64(12) #=> "7kJSM/MzBJI+75j8"

生成随机二进制字符串:

p SecureRandom.random_bytes(10) #=> "\016\t{\370g\310pbr\301" p SecureRandom.random_bytes(10) #=> "\323U\030TO\234\357\020\a\337"

生成UUID:

p SecureRandom.uuid #=> "2d931510-d99f-494a-8c67-87feb05e1594" p SecureRandom.uuid #=> "bad85eb9-0713-4da7-8d36-07a8e4b00eab"

公共类方法

字节(n)的

别名为:gen_random

gen_random(n)显示源文件

# File lib/securerandom.rb, line 50 def self.gen_random(n) @pid = 0 unless defined?(@pid) pid = $$ unless @pid == pid now = Process.clock_gettime(Process::CLOCK_REALTIME, :nanosecond) OpenSSL::Random.random_add([now, @pid, pid].join(""), 0.0) seed = Random.raw_seed(16) if (seed) OpenSSL::Random.random_add(seed, 16) end @pid = pid end return OpenSSL::Random.random_bytes(n) end

另外别名为:字节