1--TEST-- 2openssl_csr_get_subject() tests 3--EXTENSIONS-- 4openssl 5--FILE-- 6<?php 7$config = __DIR__ . DIRECTORY_SEPARATOR . 'openssl.cnf'; 8$phex = 'dcf93a0b883972ec0e19989ac5a2ce310e1d37717e8d9571bb7623731866e61e' . 9 'f75a2e27898b057f9891c2e27a639c3f29b60814581cd3b2ca3986d268370557' . 10 '7d45c2e7e52dc81c7a171876e5cea74b1448bfdfaf18828efd2519f14e45e382' . 11 '6634af1949e5b535cc829a483b8a76223e5d490a257f05bdff16f2fb22c583ab'; 12$dh_details = array('p' => $phex, 'g' => '2'); 13$dh = openssl_pkey_new(array( 14 'dh'=> array('p' => hex2bin($phex), 'g' => '2')) 15); 16 17$dn = array( 18 "countryName" => "BR", 19 "stateOrProvinceName" => "Rio Grande do Sul", 20 "localityName" => "Porto Alegre", 21 "commonName" => "Henrique do N. Angelo", 22 "emailAddress" => "hnangelo@php.net" 23); 24 25$args = array( 26 "digest_alg" => "sha1", 27 "private_key_bits" => 2048, 28 "private_key_type" => OPENSSL_KEYTYPE_DSA, 29 "encrypt_key" => true, 30 "config" => $config, 31); 32 33$privkey_file = 'file://' . __DIR__ . '/private_rsa_2048.key'; 34$csr = openssl_csr_new($dn, $privkey_file, $args); 35$csr_file = file_get_contents(__DIR__ . '/cert.csr'); 36 37var_dump(openssl_csr_get_subject($csr_file)); 38var_dump(openssl_csr_get_subject($csr, false)); 39?> 40--EXPECT-- 41array(6) { 42 ["C"]=> 43 string(2) "NL" 44 ["ST"]=> 45 string(13) "Noord Brabant" 46 ["L"]=> 47 string(4) "Uden" 48 ["O"]=> 49 string(10) "Triconnect" 50 ["OU"]=> 51 string(10) "Triconnect" 52 ["CN"]=> 53 string(15) "*.triconnect.nl" 54} 55array(6) { 56 ["countryName"]=> 57 string(2) "BR" 58 ["stateOrProvinceName"]=> 59 string(17) "Rio Grande do Sul" 60 ["localityName"]=> 61 string(12) "Porto Alegre" 62 ["commonName"]=> 63 string(21) "Henrique do N. Angelo" 64 ["emailAddress"]=> 65 string(16) "hnangelo@php.net" 66 ["organizationName"]=> 67 string(24) "Internet Widgits Pty Ltd" 68} 69