x509.MarshalPKIXPublicKey と x509.MarshalPKCS1PublicKey の違いを理解する
暗号化の領域では、DER でエンコードされた PKIX 形式と PKCS#1 の概念に遭遇することがあります。 。これらは、特に RSA 暗号化のコンテキストで、公開キーを表すために使用される 2 つの異なるエンコーディングです。 Go の関数 x509.MarshalPKIXPublicKey と x509.MarshalPKCS1PublicKey の違いを解明するには、これらの基礎となる概念を理解することが重要です。
識別エンコーディング ルールと抽象構文表記 1
識別エンコーディング ルール (DER) ) は、Abstract Syntax Notation One (ASN.1) を使用して作成されたデータ構造を、コンパクトでプラットフォームに依存しないバイナリ形式にエンコードする方法を定義します。 ASN.1 は、さまざまなプロトコルやアプリケーションで使用されるデータ型と構造を記述するための標準化された言語を提供します。
PKCS#1 は、RSA Security によって開発され、IETF によって標準化された一連の標準を指します。 PKCS#1、付録 A では、RSAPublicKey と呼ばれる RSA 公開キーを表すための ASN.1 構造が定義されています。この構造は、DER エンコード ルールを使用して DER エンコードできます。
MarshalPKIXPublicKey
Go の crypto/x509 パッケージのこの関数は、公開キーを DER エンコードされた PKIX 形式にシリアル化します。 PKIX (公開鍵インフラストラクチャ X.509) は、公開鍵証明書を表すための ASN.1 構造を主に定義する X.509 標準のバリアントです。
RSA のコンテキストでは、DER でエンコードされたPKIX 形式には次のコンポーネントが含まれます。
- AlgorithmIdentifier: 公開キーに使用されるアルゴリズム (この場合は RSA) を識別します。
- BIT STRING: DER でエンコードされた RSAPublicKey 構造が含まれます。 .
MarshalPKCS1PublicKey
この関数は、RSA 公開キーを ASN.1 DER エンコードされた PKCS#1 形式に変換します。前述したように、RSAPublicKey は、PKCS#1 で RSA 公開キーを表すために使用される ASN.1 構造です。したがって、x509.MarshalPKCS1PublicKey は RSA 公開キーを DER エンコードされた RSAPublicKey 構造にシリアル化します。
概要
本質的に、MarshalPKIXPublicKey は PKIX 形式に従って RSA 公開キーのバイナリ表現を生成します。 MarshalPKCS1PublicKey は、公開鍵のバイナリ表現を PKCS#1 形式で生成します。 PKIX 形式には、認証局や関連するアルゴリズムに関する情報など、キーそのものだけでなく、より多くのコンテキストが含まれているため、デジタル証明書での使用に適しています。
以上がGo の x509.MarshalPKIXPublicKey と x509.MarshalPKCS1PublicKey の違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

GOのコア機能には、ガベージコレクション、静的リンク、並行性サポートが含まれます。 1. GO言語の並行性モデルは、GoroutineとChannelを通じて効率的な同時プログラミングを実現します。 2.インターフェイスと多型は、インターフェイスメソッドを介して実装されているため、異なるタイプを統一された方法で処理できます。 3.基本的な使用法は、関数定義と呼び出しの効率を示しています。 4。高度な使用法では、スライスは動的なサイズ変更の強力な機能を提供します。 5.人種条件などの一般的なエラーは、Getest Raceを通じて検出および解決できます。 6.パフォーマンス最適化Sync.Poolを通じてオブジェクトを再利用して、ゴミ収集圧力を軽減します。

GO言語は、効率的でスケーラブルなシステムの構築においてうまく機能します。その利点には次のものがあります。1。高性能:マシンコードにコンパイルされ、速度速度が速い。 2。同時プログラミング:ゴルチンとチャネルを介してマルチタスクを簡素化します。 3。シンプルさ:簡潔な構文、学習コストとメンテナンスコストの削減。 4。クロスプラットフォーム:クロスプラットフォームのコンパイル、簡単な展開をサポートします。

SQLクエリの結果の並べ替えについて混乱しています。 SQLを学習する過程で、しばしば混乱する問題に遭遇します。最近、著者は「Mick-SQL Basics」を読んでいます...

テクノロジースタックの収束とテクノロジーの選択の関係ソフトウェア開発におけるテクノロジーの選択、テクノロジースタックの選択と管理は非常に重要な問題です。最近、一部の読者が提案しています...

ゴーラン...

GO言語で3つの構造を比較および処理する方法。 GOプログラミングでは、2つの構造の違いを比較し、これらの違いを...

Goでグローバルにインストールされたパッケージを表示する方法は? GO言語で開発する過程で、GOはしばしば使用します...

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか?ゴーランドを使用するためにGolandを使用する場合、多くの開発者はカスタム構造タグに遭遇します...


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 中国語版
中国語版、とても使いやすい

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
