Ruby 1.9.2 リファレンスマニュアル > ライブラリ一覧 > opensslライブラリ > OpenSSL::X509::Extensionクラス

class OpenSSL::X509::Extension

クラスの継承リスト: OpenSSL::X509::Extension < Object < Kernel < BasicObject

Abstract

X.509 v3 証明書の拡張領域のためのクラスです。OpenSSL::X509::Certificate オブジェクトは その拡張領域を Extension オブジェクトの配列として保持しています。

require 'openssl'
require 'open-uri'

der = open('http://csrc.nist.gov/pki/pkixtools/cert1.der').read
cert = OpenSSL::X509::Certificate.new(der)
p cert.extensions.class # => Array
p cert.extensions
# => [subjectKeyIdentifier = 86:CA:A5:22:81:62:EF:AD:0A:89:BC:AD:72:41:2C:29:49:F4:86:56,
      basicConstraints = critical, CA:TRUE]
p cert.extensions[0].class # => OpenSSL::X509::Extension

参照

*[RFC 3280] [[unknown:Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile|URL:http://www.ipa.go.jp/security/rfc/RFC3280-04EN.html#42]]

特異メソッド

new(oid, value, critical)

Extension オブジェクトを生成します。oid には拡張領域の OID をあらわす OpenSSL::ASN1::ObjectId オブジェクト、あるいは OID の short name か long name である文字列を与えます。value にはその値を表す DER 形式の文字列か OpenSSL::ASN1::ASN1Data のサブクラスのインスタンスを与えます。

例;

require 'openssl'
include OpenSSL
oid = "subjectKeyIdentifier"
val = "\004\024\206\312\245\"\201b\357\255\n\211\274\255rA,)I\364\206V"
ex = X509::Extension.new(oid, val)
p ex.value # => "86:CA:A5:22:81:62:EF:AD:0A:89:BC:AD:72:41:2C:29:49:F4:86:56"

インスタンスメソッド

critical=(bool)
critical?

クリティカルかどうかを設定します。

oid
oid=(oid)

OID を文字列で設定します。

to_a
to_der

DER 形式に変換します。

to_h
to_s
value
value=(value)

値を設定します。

Methods

Classes