forked from rachanon/stdbWeb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
286 lines
16 KiB
286 lines
16 KiB
9 years ago
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
|
||
|
"http://www.w3.org/TR/html4/loose.dtd">
|
||
|
<html>
|
||
|
<head>
|
||
|
<meta charset="utf-8">
|
||
|
<title>QUnit for DSA/ECDSA of X.509 ASN1 Encoder Class 'asn1x509.js'</title>
|
||
|
<script type="text/javascript" src="jquery-1.4.2.min.js"></script>
|
||
|
<script type="text/javascript" src="qunit.js"></script>
|
||
|
<link rel="stylesheet" href="qunit.css" type="text/css" media="screen" />
|
||
|
|
||
|
<script src="http://yui.yahooapis.com/2.9.0/build/yahoo/yahoo-min.js"></script>
|
||
|
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/core-min.js"></script>
|
||
|
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/enc-base64-min.js"></script>
|
||
|
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/sha1.js"></script>
|
||
|
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/md5.js"></script>
|
||
|
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/cipher-core.js"></script>
|
||
|
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/tripledes.js"></script>
|
||
|
|
||
|
<script src="../ext/jsbn.js"></script>
|
||
|
<script src="../ext/jsbn2.js"></script>
|
||
|
<script src="../ext/rsa.js"></script>
|
||
|
<script src="../ext/rsa2.js"></script>
|
||
|
<script src="../ext/base64.js"></script>
|
||
|
<script src="../base64x-1.1.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../asn1hex-1.1.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../rsapem-1.1.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../crypto-1.1.js"></script>
|
||
|
<script src="../asn1-1.0.js"></script>
|
||
|
<script src="../asn1x509-1.0.js"></script>
|
||
|
<script src="../keyutil-1.0.js"></script>
|
||
|
<script src="../rsasign-1.2.js"></script>
|
||
|
|
||
|
<script language="JavaScript" type="text/javascript" src="../ext/prng4.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../ext/rng.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../ext/ec.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../ext/ec-patch.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../ecdsa-modified-1.0.js"></script>
|
||
|
<script language="JavaScript" type="text/javascript" src="../ecparam-1.0.js"></script>
|
||
|
|
||
|
<script language="JavaScript" type="text/javascript" src="../dsa-modified-1.0.js"></script>
|
||
|
|
||
|
<script type="text/javascript">
|
||
|
<!--
|
||
|
$(document).ready(function(){
|
||
|
|
||
|
// _test/z1.*
|
||
|
var z1PubP8PEM = "" +
|
||
|
"-----BEGIN PUBLIC KEY-----\n" +
|
||
|
"MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOhmTdK0BSkSFWjzs5vJemLnujwJur3E\n" +
|
||
|
"8NzY35DreQubtkWitw4xEnR7TTxBtRQkiVEV/viPedQ+rlsaTjUY/VkCAwEAAQ==\n" +
|
||
|
"-----END PUBLIC KEY-----\n";
|
||
|
|
||
|
var z1PrvP5EPEM = "" +
|
||
|
"-----BEGIN RSA PRIVATE KEY-----\n" +
|
||
|
"Proc-Type: 4,ENCRYPTED\n" +
|
||
|
"DEK-Info: DES-EDE3-CBC,4626F2E5853E783F\n" +
|
||
|
"\n" +
|
||
|
"3vFpkrnbantC8RSzng2+jBw/VX95oi0VGKP0G8whENHUOVQXB/YOUSj+n80Y0Wwc\n" +
|
||
|
"GpeQi8U0FQdWyYv8b9aioeFB06r9t9mJsYscJ/wcIvv5tTMkr89cwN3+4GQQuqNg\n" +
|
||
|
"TmI9ekeoZ3NP26hTM4XTuFqHx4dzNNwjDLc8txc77WE/o4J4p8k9Py5yPZjs9EKy\n" +
|
||
|
"wy/yxtqQYQuFj90OMEG1G89iHTZRcq4YTZYdqg6P/XEUvyjifN+7Nym8f2N9TDDn\n" +
|
||
|
"RJtApPQlrgXvUDQKz6Lu1ZYMwe94E9YdutDGQMbxixbiyxlcxrkb/oEHH5WP5qPG\n" +
|
||
|
"w/xzh08Ce2Ftba2Q860S8nznjyZFiv+lqSKBahbujgP/63ZL+JbAd4cYBqgm4g1C\n" +
|
||
|
"YwMhHJbaVCzwYduxdyK2JBYEosDZiDfnOP4DqPhJYpg=\n" +
|
||
|
"-----END RSA PRIVATE KEY-----\n";
|
||
|
var z1PrvP5EPass = "hoge";
|
||
|
|
||
|
var z1CertPEM = "" +
|
||
|
"-----BEGIN CERTIFICATE-----\r\n" +
|
||
|
"MIIBfzCCASmgAwIBAgIBBDANBgkqhkiG9w0BAQUFADAZMQswCQYDVQQGEwJVUzEK\r\n" +
|
||
|
"MAgGA1UECgwBYTAeFw0xMzA1MDQyMzU5NTlaFw0xNDA1MDQyMzU5NTlaMBkxCzAJ\r\n" +
|
||
|
"BgNVBAYTAlVTMQowCAYDVQQKDAFiMFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOhm\r\n" +
|
||
|
"TdK0BSkSFWjzs5vJemLnujwJur3E8NzY35DreQubtkWitw4xEnR7TTxBtRQkiVEV\r\n" +
|
||
|
"/viPedQ+rlsaTjUY/VkCAwEAAaNcMFowDwYDVR0TAQH/BAUwAwEB/zALBgNVHQ8E\r\n" +
|
||
|
"BAMCBsAwJQYDVR0fBB4wHDAaoBigFoYUaHR0cDovL2FhYS5jb20vYS5jcmwwEwYD\r\n" +
|
||
|
"VR0lBAwwCgYIKwYBBQUHAwIwDQYJKoZIhvcNAQEFBQADQQAMUx/hyfWr2779id/7\r\n" +
|
||
|
"p6lHAFZTN+HBwfoq6c1reeVtk7JKD+18dYbKJcwbLLj2CEv04fm+MQ5p8mY7r5Aa\r\n" +
|
||
|
"558s\r\n" +
|
||
|
"-----END CERTIFICATE-----\r\n";
|
||
|
|
||
|
// _gitpg/jsrsasign/test/eckey/k1.*
|
||
|
var k1PubP8PEM = "" +
|
||
|
"-----BEGIN PUBLIC KEY-----\n" +
|
||
|
"MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEoBUyo8CQAFPeYPvv78ylh5MwFZjT\n" +
|
||
|
"CLQeb042TjiMJxG+9DLFmRSMlBQ9T/RsLLc+PmpB1+7yPAR+oR5gZn3kJQ==\n" +
|
||
|
"-----END PUBLIC KEY-----\n";
|
||
|
|
||
|
var k1PrvP8PPEM = "" +
|
||
|
"-----BEGIN PRIVATE KEY-----\n" +
|
||
|
"MIGHAgEAMBMGByqGSM49AgEGCCqGSM49AwEHBG0wawIBAQQgEbVzfPnZPxfAyxqE\n" +
|
||
|
"ZV05laAoJAl+/6Xt2O4mOB611sOhRANCAASgFTKjwJAAU95g++/vzKWHkzAVmNMI\n" +
|
||
|
"tB5vTjZOOIwnEb70MsWZFIyUFD1P9Gwstz4+akHX7vI8BH6hHmBmfeQl\n" +
|
||
|
"-----END PRIVATE KEY-----\n";
|
||
|
|
||
|
// _work_dsa/d1.pub.p8.pem
|
||
|
var d1PubP8PEM = "" +
|
||
|
"-----BEGIN PUBLIC KEY-----\n" +
|
||
|
"MIIBtzCCASsGByqGSM44BAEwggEeAoGBAJ7TJ6EkB8jS3Jprk1n7xI8qMXUE8ztI\n" +
|
||
|
"ZhxLA3ePVbgYryGShbvN+mD2P5b1w8BnONckMqNvRtZJCg/nAjhRdnHnq9tDDE/7\n" +
|
||
|
"dKF/ttDOzu4o/dtJJzvNFlpSDkqXF7TSfvBvNBffap6i2jUFjxGa52rICVosRe5X\n" +
|
||
|
"bD3+glPzRJpPAhUAgyEkwxiCmPjW3RrYQSHC7zOl1SsCgYBxGsQFO69QKqCgmry3\n" +
|
||
|
"r3KIVJXh77DeEp2Tx7sW8OS4ChoQ0ECe1SvNDfC1UR9uCPdHFVF+lAbt1F148O8V\n" +
|
||
|
"2Ssn7zmOp7+TZfoTWRMiFJ+oRjUYfaJ38Vy8jJooQj/rIzIh5dGtNtkm0uHgx3Dz\n" +
|
||
|
"TcBKYW9VaFIiqbHPT47Ph8GbfgOBhQACgYEAjK/ZZUzlGBjhVGE70LFO6XT73/xa\n" +
|
||
|
"GYAsQwEwK8hU1eF9rw1nRaSqqORv+WtXyJNx+nLMoSoiSIIWRdH/dYaaJUmtf9EQ\n" +
|
||
|
"zu/qVhbQC+WUEDbhoth7vPC/vmw7Hhi6DTs69tNLrPYTJwoLX2fHhmjkuls+wKoo\n" +
|
||
|
"52LqH58uAWfgUjs=\n" +
|
||
|
"-----END PUBLIC KEY-----\n";
|
||
|
|
||
|
var d1PrvP5EPEM = "" +
|
||
|
"-----BEGIN DSA PRIVATE KEY-----\n" +
|
||
|
"Proc-Type: 4,ENCRYPTED\n" +
|
||
|
"DEK-Info: DES-EDE3-CBC,0A4241238121CC53\n" +
|
||
|
"\n" +
|
||
|
"SREBGTs1GdPEyT0O4MQIPfZZ59Wj8dcvqyEv+IlHzztZbqUiBfGYidu5ybhhaq8W\n" +
|
||
|
"FvDLUTyUPhWqjnTPI0P73t/nMFhZEEB/PWP4SCCXcsd+8ygIEVQfXl9CcFfFxsiP\n" +
|
||
|
"UhRBaZrU/yQ/IynKSboA/RfysHyfJTn3GcJLmMDhs7x4yZr+E8FIfk15qXCkzEsH\n" +
|
||
|
"yFkhDi0D23RfttXie5HiQE0e2XsB127aCkYfQ5nMesrGTVtQb+8cuodtejmGtFtT\n" +
|
||
|
"kslgs45yRNUznxxMi/61sm6pkH///ow0w5DN74UQsqpJj4CYhhNQY4r/QnK8SvlL\n" +
|
||
|
"+KFXazkFwWNZbXiyxF7zdaCsb5bglvfmJspSDGUIcxPzwMG1GQBA3IqOegjmgU/5\n" +
|
||
|
"LMElak/HMFFjT+jUUvxVSJIWK7f4+lWypwPkmmZib9dx8XHPpUr/vXBwPLE40fRG\n" +
|
||
|
"9enP7lSZRWjmW9alWIn6dpjG5HsQwH4eMxdD1fqLR7BR+nx+z47wqmAXPIzOL7PW\n" +
|
||
|
"N4nVxc1+juzITbT6HZB5gkHJG/5l/YFDsACK8aLHp+lgM/Onyg3cMDKSbaXERPZb\n" +
|
||
|
"q0MrwzdrLyCc6x9HYz2QDA==\n" +
|
||
|
"-----END DSA PRIVATE KEY-----\n";
|
||
|
var d1PrvP5EPass = "passwd";
|
||
|
|
||
|
// ======= TEST ===============================================================
|
||
|
|
||
|
// AlgorithmIdentifier Test
|
||
|
|
||
|
test("AlgorithmIdentifier SHA1withECDSA", function() {
|
||
|
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA1withECDSA', paramempty: true});
|
||
|
equal(o.getEncodedHex(), "300906072a8648ce3d0401", "aaa");
|
||
|
});
|
||
|
|
||
|
test("AlgorithmIdentifier SHA256withECDSA", function() {
|
||
|
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA256withECDSA', paramempty: true});
|
||
|
equal(o.getEncodedHex(), "300a06082a8648ce3d040302", "aaa");
|
||
|
});
|
||
|
|
||
|
test("AlgorithmIdentifier SHA1withDSA", function() {
|
||
|
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA1withDSA', paramempty: true});
|
||
|
equal(o.getEncodedHex(), "300906072a8648ce380403", "aaa");
|
||
|
});
|
||
|
|
||
|
test("AlgorithmIdentifier SHA256withDSA", function() {
|
||
|
var o = new KJUR.asn1.x509.AlgorithmIdentifier({name: 'SHA256withDSA', paramempty: true});
|
||
|
equal(o.getEncodedHex(), "300b0609608648016503040302", "aaa");
|
||
|
});
|
||
|
|
||
|
// SubjectPublicKeyInfo Test
|
||
|
|
||
|
test("SubjectPublicKeyInfo k1(EC secp256r1)", function() {
|
||
|
var key = KEYUTIL.getKey(k1PubP8PEM);
|
||
|
var obj = new KJUR.asn1.x509.SubjectPublicKeyInfo(key);
|
||
|
equal(obj.getEncodedHex(), "3059301306072a8648ce3d020106082a8648ce3d03010703420004a01532a3c0900053de60fbefefcca58793301598d308b41e6f4e364e388c2711bef432c599148c94143d4ff46c2cb73e3e6a41d7eef23c047ea11e60667de425", "aaa")
|
||
|
});
|
||
|
|
||
|
test("SubjectPublicKeyInfo d1(DSA)", function() {
|
||
|
var key = KEYUTIL.getKey(d1PubP8PEM);
|
||
|
var obj = new KJUR.asn1.x509.SubjectPublicKeyInfo(key);
|
||
|
equal(obj.getEncodedHex(), "308201b73082012b06072a8648ce3804013082011e028181009ed327a12407c8d2dc9a6b9359fbc48f2a317504f33b48661c4b03778f55b818af219285bbcdfa60f63f96f5c3c06738d72432a36f46d6490a0fe70238517671e7abdb430c4ffb74a17fb6d0ceceee28fddb49273bcd165a520e4a9717b4d27ef06f3417df6a9ea2da35058f119ae76ac8095a2c45ee576c3dfe8253f3449a4f021500832124c3188298f8d6dd1ad84121c2ef33a5d52b028180711ac4053baf502aa0a09abcb7af72885495e1efb0de129d93c7bb16f0e4b80a1a10d0409ed52bcd0df0b5511f6e08f74715517e9406edd45d78f0ef15d92b27ef398ea7bf9365fa13591322149fa84635187da277f15cbc8c9a28423feb233221e5d1ad36d926d2e1e0c770f34dc04a616f55685222a9b1cf4f8ecf87c19b7e03818500028181008cafd9654ce51818e154613bd0b14ee974fbdffc5a19802c4301302bc854d5e17daf0d6745a4aaa8e46ff96b57c89371fa72cca12a2248821645d1ff75869a2549ad7fd110ceefea5616d00be5941036e1a2d87bbcf0bfbe6c3b1e18ba0d3b3af6d34bacf613270a0b5f67c78668e4ba5b3ec0aa28e762ea1f9f2e0167e0523b", "aaa");
|
||
|
});
|
||
|
// 308201b43082012b06072a8648ce3804013082011e028181009ed327a12407c8d2dc9a6b9359fbc48f2a317504f33b48661c4b03778f55b818af219285bbcdfa60f63f96f5c3c06738d72432a36f46d6490a0fe70238517671e7abdb430c4ffb74a17fb6d0ceceee28fddb49273bcd165a520e4a9717b4d27ef06f3417df6a9ea2da35058f119ae76ac8095a2c45ee576c3dfe8253f3449a4f021500832124c3188298f8d6dd1ad84121c2ef33a5d52b028180711ac4053baf502aa0a09abcb7af72885495e1efb0de129d93c7bb16f0e4b80a1a10d0409ed52bcd0df0b5511f6e08f74715517e9406edd45d78f0ef15d92b27ef398ea7bf9365fa13591322149fa84635187da277f15cbc8c9a28423feb233221e5d1ad36d926d2e1e0c770f34dc04a616f55685222a9b1cf4f8ecf87c19b7e03818200008cafd9654ce51818e154613bd0b14ee974fbdffc5a19802c4301302bc854d5e17daf0d6745a4aaa8e46ff96b57c89371fa72cca12a2248821645d1ff75869a2549ad7fd110ceefea5616d00be5941036e1a2d87bbcf0bfbe6c3b1e18ba0d3b3af6d34bacf613270a0b5f67c78668e4ba5b3ec0aa28e762ea1f9f2e0167e0523b
|
||
|
|
||
|
|
||
|
// newCertPEM Test
|
||
|
|
||
|
test("newCertPEM z1(RSA)", function() {
|
||
|
var pem = KJUR.asn1.x509.X509Util.newCertPEM(
|
||
|
{ serial: {int: 4},
|
||
|
sigalg: {name: 'SHA1withRSA'},
|
||
|
issuer: {str: '/C=US/O=a'},
|
||
|
notbefore: {'str': '130504235959Z'},
|
||
|
notafter: {'str': '140504235959Z'},
|
||
|
subject: {str: '/C=US/O=b'},
|
||
|
sbjpubkey: z1PubP8PEM,
|
||
|
ext: [
|
||
|
{basicConstraints: {cA: true, critical: true}},
|
||
|
{keyUsage: {bin: '11'}},
|
||
|
{cRLDistributionPoints: {uri: 'http://aaa.com/a.crl'}},
|
||
|
{extKeyUsage: {array: [{name: 'clientAuth'}]}},
|
||
|
],
|
||
|
cakey: [z1PrvP5EPEM, z1PrvP5EPass]});
|
||
|
equal(pem, z1CertPEM, "bbb");
|
||
|
});
|
||
|
|
||
|
test("newCertPEM k1(ECDSA secp256r1)", function() {
|
||
|
var pem = KJUR.asn1.x509.X509Util.newCertPEM(
|
||
|
{ serial: {int: 4},
|
||
|
sigalg: {name: 'SHA256withECDSA', paramempty: true},
|
||
|
issuer: {str: '/C=US/O=a'},
|
||
|
notbefore: {'str': '130504235959Z'},
|
||
|
notafter: {'str': '140504235959Z'},
|
||
|
subject: {str: '/C=US/O=b'},
|
||
|
sbjpubkey: k1PubP8PEM,
|
||
|
ext: [
|
||
|
{basicConstraints: {cA: true, critical: true}},
|
||
|
{keyUsage: {bin: '11'}},
|
||
|
{cRLDistributionPoints: {uri: 'http://aaa.com/a.crl'}},
|
||
|
{extKeyUsage: {array: [{name: 'clientAuth'}]}},
|
||
|
],
|
||
|
cakey: [k1PrvP8PPEM]});
|
||
|
var hex = KEYUTIL.getHexFromPEM(pem, "CERTIFICATE");
|
||
|
var tbsHex = ASN1HEX.getDecendantHexTLVByNthList(hex, 0, [0]);
|
||
|
equal(tbsHex, "30820123a003020102020104300a06082a8648ce3d0403023019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a3008060355040a0c01623059301306072a8648ce3d020106082a8648ce3d03010703420004a01532a3c0900053de60fbefefcca58793301598d308b41e6f4e364e388c2711bef432c599148c94143d4ff46c2cb73e3e6a41d7eef23c047ea11e60667de425a35c305a300f0603551d130101ff040530030101ff300b0603551d0f0404030206c030250603551d1f041e301c301aa018a0168614687474703a2f2f6161612e636f6d2f612e63726c30130603551d25040c300a06082b06010505070302", "expected tbsCert");
|
||
|
});
|
||
|
|
||
|
test("newCertPEM d1(DSA)", function() {
|
||
|
var pem = KJUR.asn1.x509.X509Util.newCertPEM(
|
||
|
{ serial: {int: 4},
|
||
|
sigalg: {name: 'SHA1withDSA', paramempty: true},
|
||
|
issuer: {str: '/C=US/O=a'},
|
||
|
notbefore: {'str': '130504235959Z'},
|
||
|
notafter: {'str': '140504235959Z'},
|
||
|
subject: {str: '/C=US/O=b'},
|
||
|
sbjpubkey: d1PubP8PEM,
|
||
|
ext: [
|
||
|
{basicConstraints: {cA: true, critical: true}},
|
||
|
{keyUsage: {bin: '11'}},
|
||
|
{cRLDistributionPoints: {uri: 'http://aaa.com/a.crl'}},
|
||
|
{extKeyUsage: {array: [{name: 'clientAuth'}]}},
|
||
|
],
|
||
|
cakey: [d1PrvP5EPEM, d1PrvP5EPass]});
|
||
|
var hex = KEYUTIL.getHexFromPEM(pem, "CERTIFICATE");
|
||
|
var tbsHex = ASN1HEX.getDecendantHexTLVByNthList(hex, 0, [0]);
|
||
|
equal(tbsHex, "30820282a003020102020104300906072a8648ce3804033019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a3008060355040a0c0162308201b73082012b06072a8648ce3804013082011e028181009ed327a12407c8d2dc9a6b9359fbc48f2a317504f33b48661c4b03778f55b818af219285bbcdfa60f63f96f5c3c06738d72432a36f46d6490a0fe70238517671e7abdb430c4ffb74a17fb6d0ceceee28fddb49273bcd165a520e4a9717b4d27ef06f3417df6a9ea2da35058f119ae76ac8095a2c45ee576c3dfe8253f3449a4f021500832124c3188298f8d6dd1ad84121c2ef33a5d52b028180711ac4053baf502aa0a09abcb7af72885495e1efb0de129d93c7bb16f0e4b80a1a10d0409ed52bcd0df0b5511f6e08f74715517e9406edd45d78f0ef15d92b27ef398ea7bf9365fa13591322149fa84635187da277f15cbc8c9a28423feb233221e5d1ad36d926d2e1e0c770f34dc04a616f55685222a9b1cf4f8ecf87c19b7e03818500028181008cafd9654ce51818e154613bd0b14ee974fbdffc5a19802c4301302bc854d5e17daf0d6745a4aaa8e46ff96b57c89371fa72cca12a2248821645d1ff75869a2549ad7fd110ceefea5616d00be5941036e1a2d87bbcf0bfbe6c3b1e18ba0d3b3af6d34bacf613270a0b5f67c78668e4ba5b3ec0aa28e762ea1f9f2e0167e0523ba35c305a300f0603551d130101ff040530030101ff300b0603551d0f0404030206c030250603551d1f041e301c301aa018a0168614687474703a2f2f6161612e636f6d2f612e63726c30130603551d25040c300a06082b06010505070302", "expected tbsCert");
|
||
|
});
|
||
|
|
||
|
test("newCertPEM by sighex(RSA)", function() {
|
||
|
var pem = KJUR.asn1.x509.X509Util.newCertPEM(
|
||
|
{ serial: {int: 1},
|
||
|
sigalg: {name: 'SHA1withRSA', paramempty: true},
|
||
|
issuer: {str: '/C=US/O=r1'},
|
||
|
notbefore: {'str': '130504235959Z'},
|
||
|
notafter: {'str': '140504235959Z'},
|
||
|
subject: {str: '/C=US/O=r1'},
|
||
|
sbjpubkey: z1PubP8PEM,
|
||
|
sighex: '0102030405060708'});
|
||
|
var hex = KEYUTIL.getHexFromPEM(pem, "CERTIFICATE");
|
||
|
var tbsHex = ASN1HEX.getDecendantHexTLVByNthList(hex, 0, [0]);
|
||
|
//alert(pem);
|
||
|
expect(2);
|
||
|
|
||
|
equal(tbsHex, "3081cba003020102020101300b06092a864886f70d010105301a310b3009060355040613025553310b3009060355040a0c027231301e170d3133303530343233353935395a170d3134303530343233353935395a301a310b3009060355040613025553310b3009060355040a0c027231305c300d06092a864886f70d0101010500034b003048024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001", "expected tbsCert");
|
||
|
|
||
|
equal(hex, "3081e63081cba003020102020101300b06092a864886f70d010105301a310b3009060355040613025553310b3009060355040a0c027231301e170d3133303530343233353935395a170d3134303530343233353935395a301a310b3009060355040613025553310b3009060355040a0c027231305c300d06092a864886f70d0101010500034b003048024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001300b06092a864886f70d0101050309000102030405060708", "fake cert");
|
||
|
});
|
||
|
|
||
|
test("newCertPEM by issues object, sighex(RSA)", function() {
|
||
|
var pem = KJUR.asn1.x509.X509Util.newCertPEM(
|
||
|
{ serial: {int: 1},
|
||
|
sigalg: {name: 'SHA1withRSA', paramempty: true},
|
||
|
issuer: {
|
||
|
C: 'US',
|
||
|
O: 'r1',
|
||
|
CN: 'http://www.github.com/kjur//'
|
||
|
},
|
||
|
notbefore: {'str': '130504235959Z'},
|
||
|
notafter: {'str': '140504235959Z'},
|
||
|
subject: {str: '/C=US/O=r1'},
|
||
|
sbjpubkey: z1PubP8PEM,
|
||
|
sighex: '0102030405060708'});
|
||
|
var hex = KEYUTIL.getHexFromPEM(pem, "CERTIFICATE");
|
||
|
var tbsHex = ASN1HEX.getDecendantHexTLVByNthList(hex, 0, [0]);
|
||
|
expect(2);
|
||
|
|
||
|
equal(tbsHex, "3081b1a003020102020101300b06092a864886f70d0101053000301e170d3133303530343233353935395a170d3134303530343233353935395a301a310b3009060355040613025553310b3009060355040a0c027231305c300d06092a864886f70d0101010500034b003048024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001", "expected tbsCert");
|
||
|
|
||
|
equal(hex, "3081cc3081b1a003020102020101300b06092a864886f70d0101053000301e170d3133303530343233353935395a170d3134303530343233353935395a301a310b3009060355040613025553310b3009060355040a0c027231305c300d06092a864886f70d0101010500034b003048024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001300b06092a864886f70d0101050309000102030405060708", "fake cert");
|
||
|
});
|
||
|
|
||
|
});
|
||
|
|
||
|
-->
|
||
|
</script>
|
||
|
|
||
|
</head>
|
||
|
<body>
|
||
|
<div id="qunit"></div>
|
||
|
<div id="qunit-fixture">test markup</div>
|
||
|
</body>
|
||
|
</html>
|
||
|
|