當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript pki.certificateFromPem方法代碼示例

本文整理匯總了TypeScript中node-forge.pki.certificateFromPem方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript pki.certificateFromPem方法的具體用法?TypeScript pki.certificateFromPem怎麽用?TypeScript pki.certificateFromPem使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在node-forge.pki的用法示例。


在下文中一共展示了pki.certificateFromPem方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: verifySigningChain

  verifySigningChain(certChain: string | ICert[] | ICert): boolean {
    let forgeCertArray: any[] = [];

    if (typeof certChain === "string") {
      const rPEM = /\s*-----BEGIN ([A-Z0-9- ]+)-----\r?\n?([\x21-\x7e\s]+?(?:\r?\n\r?\n))?([:A-Za-z0-9+\/=\s]+?)-----END \1-----/g;
      let forgeCert: any;
      let match;

      while((match = rPEM.exec(certChain)) !== null) {
        try {
          forgeCert = forge.pki.certificateFromPem(match[0]);
        } catch (error) {
          throw new Error(``);
        }
        forgeCertArray.push(forgeCert);
      }
    } else if (Array.isArray(certChain)) {
      for (let cert of certChain) {
        if (isICert(cert)) {
          forgeCertArray.push(forge.pki.certificateFromPem(cert.pem));
        } else {
          throw new Error(``);
        }
      }
    } else if (isICert(certChain)) {
      forgeCertArray.push(forge.pki.certificateFromPem(certChain.pem));
    } else {
      throw new Error(``);
    }

    return forge.pki.verifyCertificateChain(this._forgeCAStore, forgeCertArray, true);
  }
開發者ID:zachmart,項目名稱:closedssl,代碼行數:32,代碼來源:CAStore.ts

示例2: fingerprint

  fingerprint(hash: "sha1" | "sha256" | "sha384" | "sha512" | "md5" = "sha1"): string {
    let md: any;
    const forgeCSR = forge.pki.certificateFromPem(this._pem, true, true);

    switch (hash) {
      case "sha1":
        md = forge.md.sha1.create();
        break;
      case "sha256":
        md = forge.md.sha256.create();
        break;
      case "sha384":
        md = forge.md.sha384.create();
        break;
      case "sha512":
        md = forge.md.sha512.create();
        break;
      case "md5":
        md = forge.md.md5.create();
        break;
      default:
        throw new Error(`Unrecognized message digest hash algorithm: ${hash}`);
    }

    const result = md
      .update(forge.asn1.toDer(forge.pki.certificateToAsn1(forgeCSR)).getBytes())
      .digest()
      .toHex();

    return result;
  }
開發者ID:zachmart,項目名稱:closedssl,代碼行數:31,代碼來源:Cert.ts

示例3: convertICertOrPEMStringToForgeCert

function convertICertOrPEMStringToForgeCert(cert: ICert | string): any {
  let certPEM: string;
  let forgeCert: any;

  if (isICert(cert)) {
    certPEM = cert.pem;
  } else if (typeof cert === "string") {
    certPEM = cert;
  } else {
    throw new Error(``);
  }

  try {
    forgeCert = forge.pki.certificateFromPem(certPEM);
  } catch (error) {
    throw new Error(``);
  }

  return forgeCert;
}
開發者ID:zachmart,項目名稱:closedssl,代碼行數:20,代碼來源:CAStore.ts

示例4: constructor

  constructor(arg: string | ICert) {
    if (isICert(arg)) {
      this._publicKeyPEM = arg.publicKeyPEM;
      this._numBits = arg.numBits;
      this._pem = arg.pem;
      this._subject = arg.subject;
      this._issuer = arg.issuer;
      this._v3Extensions = arg.v3Extensions;
      this._serial = arg.serial;
      this._hash = arg.hash;
      this._startDate = (typeof arg.startDate === "number") ?
        new Date(arg.startDate)
        :
        arg.startDate;
      this._endDate = (typeof arg.endDate === "number") ?
        new Date(arg.endDate)
        :
        arg.endDate;
    } else if (typeof arg === "string") {
      let forgeCert: any;

      try {
        forgeCert = forge.pki.certificateFromPem(arg, true, true);
      } catch (error) {
        throw new Error(`Could not construct Cert from given pem string "${arg}"${"\n"
          }issue: ${error.message}`);
      }
      this._publicKeyPEM = forge.pki.publicKeyToPem(forgeCert.publicKey);
      this._numBits = forgeCert.publicKey.n.bitLength();
      this._pem = arg;
      this._subject = DistinguishedName.forgeCSROrCertToIDN(forgeCert, "subject");
      this._issuer = DistinguishedName.forgeCSROrCertToIDN(forgeCert, "issuer");
      this._v3Extensions = forgeCSROrCertToV3ExtensionArray(forgeCert);
      this._serial = parseInt(forgeCert.serialNumber, 16);
      this._hash = forgeCert.md.algorithm;
      this._startDate = forgeCert.validity.notBefore;
      this._endDate = forgeCert.validity.notAfter;
    } else {
      throw new Error(`The Cert constructor argument "${arg}" is not acceptable`);
    }
  }
開發者ID:zachmart,項目名稱:closedssl,代碼行數:41,代碼來源:Cert.ts

示例5:

import * as forge from 'node-forge';

let keypair = forge.pki.rsa.generateKeyPair({ bits: 512 });
let privateKeyPem = forge.pki.privateKeyToPem(keypair.privateKey);
let publicKeyPem = forge.pki.publicKeyToPem(keypair.publicKey);
let key = forge.pki.decryptRsaPrivateKey(privateKeyPem);
let x: string = forge.ssh.privateKeyToOpenSSH(key);
let pemKey: forge.pki.PEM = publicKeyPem;
let publicKeyRsa = forge.pki.publicKeyFromPem(pemKey);
let privateKeyRsa = forge.pki.privateKeyFromPem(privateKeyPem);
let privateKeyRsa2 = forge.pki.privateKeyInfoToPem(privateKeyRsa);
let byteBufferString = forge.pki.pemToDer(privateKeyPem);
let certPem = forge.pki.certificateFromPem(pemKey);
let cert = forge.pki.createCertificate();

{
    let subjectPublicKeyInfo = forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.SEQUENCE, true, [
        forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.SEQUENCE, true, [
            forge.asn1.create(
                forge.asn1.Class.UNIVERSAL,
                forge.asn1.Type.OID,
                false,
                forge.asn1.oidToDer(forge.pki.oids['rsaEncryption']).getBytes()
            ),
            forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.NULL, false, '')
        ]),
        forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.BITSTRING, false, [
            forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.SEQUENCE, true, [
                forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.INTEGER, false, []),
                forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.INTEGER, false, [])
            ])
開發者ID:geirsagberg,項目名稱:DefinitelyTyped,代碼行數:31,代碼來源:node-forge-tests.ts


注:本文中的node-forge.pki.certificateFromPem方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。