ホームページ > バックエンド開発 > Golang > Go の `MarshalPKIXPublicKey()` と `MarshalPKCS1PublicKey()` の違いは何ですか?

Go の `MarshalPKIXPublicKey()` と `MarshalPKCS1PublicKey()` の違いは何ですか?

Susan Sarandon
リリース: 2024-11-04 09:32:02
オリジナル
676 人が閲覧しました

What's the difference between `MarshalPKIXPublicKey()` and `MarshalPKCS1PublicKey()` in Go?

MarshalPKIXPublicKey() と MarshalPKCS1PublicKey() の違いを理解する

Go 標準ライブラリでは、x509.MarshalPKIXPublicKey() と x509.MarshalPKCS1PublicKey () は、DER エンコード形式への公開キーのシリアル化を容易にする 2 つの関数です。

ASN.1 および DER

2 つの関数の違いを詳しく説明する前に

  • ASN.1 (抽象構文表記 1): システム間で共有されるデータ構造を記述するために広く使用されている表記法です。
  • DER (Distinguished Encoding Rules): ASN.1 データをコンパクトなバイナリ形式で表すために使用される特定のエンコード スキーム。

MarshalPKCS1PublicKey()

  • RSA 公開キーを PKCS#1 ASN.1 構造の DER エンコード表現にシリアル化します。
  • PKCS#1 標準は、RSA 公開キーを表す方法を定義します。
  • この関数は、PKCS#1 の RSAPublicKey ASN.1 構造を使用して、公開キーを DER エンコードされた文字列にエンコードします。

MarshalPKIXPublicKey()

  • 公開キーを PKIX/X.509 の SubjectPublicKeyInfo 構造の DER エンコード表現にシリアル化します。
  • PKIX/X.509 は、X.509 のインターネット バリアントです。
  • RSA 公開鍵の場合、この DER エンコード表現には RSA のアルゴリズム識別子 (OID 1.2.840.113549.1.1.1) が含まれます。パラメータ NULL と、DER でエンコードされた PKCS#1 RSAPublicKey 構造体。

以上がGo の `MarshalPKIXPublicKey()` と `MarshalPKCS1PublicKey()` の違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート