mirror of
https://github.com/php/php-src.git
synced 2024-12-16 13:26:19 +08:00
63 lines
2.2 KiB
PHP
63 lines
2.2 KiB
PHP
--TEST--
|
|
Testing openssl_spki_export()
|
|
Creates SPKAC for all available key sizes & signature algorithms and exports public key
|
|
--SKIPIF--
|
|
<?php
|
|
if (!extension_loaded("openssl")) die("skip");
|
|
if (!@openssl_pkey_new()) die("skip cannot create private key");
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
|
|
/* array of private key sizes to test */
|
|
$ksize = array('1024'=>1024,
|
|
'2048'=>2048,
|
|
'4096'=>4096);
|
|
|
|
/* array of available hashings to test */
|
|
$algo = array('md4'=>OPENSSL_ALGO_MD4,
|
|
'md5'=>OPENSSL_ALGO_MD5,
|
|
'sha1'=>OPENSSL_ALGO_SHA1,
|
|
'sha224'=>OPENSSL_ALGO_SHA224,
|
|
'sha256'=>OPENSSL_ALGO_SHA256,
|
|
'sha384'=>OPENSSL_ALGO_SHA384,
|
|
'sha512'=>OPENSSL_ALGO_SHA512,
|
|
'rmd160'=>OPENSSL_ALGO_RMD160);
|
|
|
|
/* loop over key sizes for test */
|
|
foreach($ksize as $k => $v) {
|
|
|
|
/* generate new private key of specified size to use for tests */
|
|
$pkey = openssl_pkey_new(array('digest_alg' => 'sha512',
|
|
'private_key_type' => OPENSSL_KEYTYPE_RSA,
|
|
'private_key_bits' => $v));
|
|
openssl_pkey_export($pkey, $pass);
|
|
|
|
/* loop to create and verify results */
|
|
foreach($algo as $key => $value) {
|
|
$spkac = openssl_spki_new($pkey, _uuid(), $value);
|
|
echo openssl_spki_export(preg_replace('/SPKAC=/', '', $spkac));
|
|
}
|
|
openssl_free_key($pkey);
|
|
}
|
|
|
|
/* generate a random challenge */
|
|
function _uuid()
|
|
{
|
|
return sprintf('%04x%04x-%04x-%04x-%04x-%04x%04x%04x', mt_rand(0, 0xffff),
|
|
mt_rand(0, 0xffff), mt_rand(0, 0xffff), mt_rand(0, 0x0fff) | 0x4000,
|
|
mt_rand(0, 0x3fff) | 0x8000, mt_rand(0, 0xffff),
|
|
mt_rand(0, 0xffff), mt_rand(0, 0xffff));
|
|
}
|
|
|
|
?>
|
|
--EXPECTREGEX--
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|
|
\-\-\-\-\-BEGIN PUBLIC KEY\-\-\-\-\-.*\-\-\-\-\-END PUBLIC KEY\-\-\-\-\-
|