本文整理汇总了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);
}
示例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;
}
示例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;
}
示例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`);
}
}
示例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, [])
])