Skip to content

Tutorial for generating X.509 certificate

Kenji Urushima edited this page Apr 26, 2021 · 10 revisions
var rs = require("jsrsasign");

var kp = rs.KEYUTIL.generateKeypair("EC", "secp256r1");
var prv = kp.prvKeyObj;
var pub = kp.pubKeyObj;
var prvpem = rs.KEYUTIL.getPEM(prv, "PKCS8PRV");
var pubpem = rs.KEYUTIL.getPEM(pub, "PKCS8PUB");

var x = new rs.KJUR.asn1.x509.Certificate({
  version: 3,
  serial: {int: 4},
  issuer: {str: "/CN=UserCA"},
  notbefore: "201231235959Z",
  notafter:  "221231235959Z",
  subject: {str: "/CN=User1"},
  sbjpubkey: pub,
  ext: [
    {extname: "basicConstraints", cA: false},
    {extname: "keyUsage", names:["digitalSignature"]},
    {extname: "cRLDistributionPoints",
     array: [{fulluri: 'http://example.com/a.crl'}]}
  ],
  sigalg: "SHA256withECDSA",
  cakey: prv
});

console.log(prvpem);
console.log(pubpem);
console.log(x.getPEM());
Clone this wiki locally