Получите открытый ключ из закрытого ключа с помощью crypto.subtle

У меня есть закрытый ключ RSA pkcs8, который я использую в приложении для подписи запроса. Я хочу получить открытый ключ из этого закрытого ключа с помощью javascript window.crypto.subtle без использования каких-либо внешних библиотек..

Я импортирую свой закрытый ключ в соответствии с документацией по тонкой криптографии.

function str2ab(str) {
  const buf = new ArrayBuffer(str.length);
  const bufView = new Uint8Array(buf);
  for (let i = 0, strLen = str.length; i < strLen; i++) {
    bufView[i] = str.charCodeAt(i);
  }
  return buf;
}

function importPrivateKey(KEY) {
  const pemHeader = "-----BEGIN PRIVATE KEY-----";
  const pemFooter = "-----END PRIVATE KEY-----";
  const pemContents = KEY.substring(pemHeader.length, KEY.length - pemFooter.length);
  const binaryDerString = window.atob(pemContents);  
  const binaryDer = str2ab(binaryDerString);

  // return a CryptoKey object
  return window.crypto.subtle.importKey(
    "pkcs8",
    binaryDer,
    {
      name: "RSASSA-PKCS1-v1_5",
      modulusLength: 2048,
      publicExponent: new Uint8Array([1, 0, 1]),
      hash: "SHA-256",
    },
    true,
    ["sign"]
  );
}

Как получить открытый ключ из этого закрытого ключа?

0 ответов

Другие вопросы по тегам