From c01943bffc8b719e552d307f522820d50f783a4c Mon Sep 17 00:00:00 2001 From: Anatol Belski Date: Fri, 3 Jul 2015 10:15:52 +0200 Subject: [PATCH] fix improper behavior openssl_spki_export() is documented to return string, but it's obviously not achieved writing it to stdout :) --- ext/openssl/openssl.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/ext/openssl/openssl.c b/ext/openssl/openssl.c index ebbc877c43..b3ef5ad003 100644 --- a/ext/openssl/openssl.c +++ b/ext/openssl/openssl.c @@ -1637,7 +1637,7 @@ PHP_FUNCTION(openssl_spki_export) EVP_PKEY *pkey = NULL; NETSCAPE_SPKI *spki = NULL; - BIO *out = BIO_new(BIO_s_mem()); + BIO *out = NULL; if (zend_parse_parameters(ZEND_NUM_ARGS(), "s", &spkstr, &spkstr_len) == FAILURE) { return; @@ -1669,8 +1669,13 @@ PHP_FUNCTION(openssl_spki_export) goto cleanup; } - out = BIO_new_fp(stdout, BIO_NOCLOSE); - PEM_write_bio_PUBKEY(out, pkey); + out = BIO_new(BIO_s_mem()); + if (out && PEM_write_bio_PUBKEY(out, pkey)) { + BUF_MEM *bio_buf; + + BIO_get_mem_ptr(out, &bio_buf); + RETVAL_STRINGL((char *)bio_buf->data, bio_buf->length); + } goto cleanup; cleanup: -- 2.50.1