new(str, base=10) -> OpenSSL::BN
[permalink][rdoc][edit]-
文字列を多倍長整数オブジェクト(OpenSSL::BN)を生成します。
base で、変換方法(基数)を指定します。デフォルトは 10 で、他に 16, 2, 0 を指定できます。
10 引数の文字列を 10進数とみなして、変換します。 16 引数の文字列を 16進数とみなして、変換します。 2 引数の文字列を big-endian の符号無し整数のバイナリ列とみなして、変換します。 0 引数の文字列を MPI形式の文字列(バイト列)とみなして、変換します。 (最初の4byteはbig-endianでデータ長を表わし、その後にそのデータ長のバイト 列(big-endian)で数値を表す。最上位ビットが立っていると負数)。
require 'openssl' OpenSSL::BN.new("-241") # => -241 OpenSSL::BN.new("ff00",16) # => 65280 OpenSSL::BN.new("\x81",2) # => 129 OpenSSL::BN.new("\xff\x81",2) # => 65409 OpenSSL::BN.new("\x00\x00\x00\x02\x00\x81", 0) # => 129 OpenSSL::BN.new("\x00\x00\x00\x02\x80\x81", 0) # => -129 OpenSSL::BN.new(1209) # => 1209
- [PARAM] str:
- 整数を表す文字列
- [PARAM] base:
- 文字列から整数に変換するときの基数
- [EXCEPTION] OpenSSL::BNError:
- 変換に失敗した場合に発生します
反対に、OpenSSL::BN クラスのオブジェクトを文字列にするには、 OpenSSL::BN#to_s を用います。
[SEE_ALSO] OpenSSL::BN#to_s
new(bn) -> OpenSSL::BN
[permalink][rdoc][edit]-
OpenSSL::BN を複製して返します。
- [PARAM] bn:
- 複製する OpenSSL::BN オブジェクト
new(integer) -> OpenSSL::BN
[permalink][rdoc][edit]-
整数オブジェクト(Integer)から多倍長整数オブジェクト (OpenSSL::BN)を生成します。
- [PARAM] integer:
- 整数オブジェクト
[SEE_ALSO] Integer#to_bn