Hello, first of all, I'm not into this at all, a colleague at work told me about this. The following is the problem: When enrypting data with openssl_public_encrypt(), this goes well up to a certain length (tested limit: 245 bytes of data to be encrypted), but as of a certain length (246 bytes), the function returns FALSE with no note whatsoever why it went wrong.
Is this expected behaviour? Is the length of the input data limited or constrained by the length of the public key? In this case, shouldn't there be a warning? Steps to reproduce: 1) Generate a 2048 byte key: $ openssl genrsa 2048 -rand >my.key 2) Sign it $ openssl req -new -x509 -key my.key >my.cert 3) Place the attached script "openssl.php" in the same directory and execute it: $ php openssl.php 245 ---> Get public key from my.cert: resource(5) of type (OpenSSL key) ---> Encrypt 245 bytes of data using public key: bool(true) ---> Freeing public key: NULL ---> Encoding 256 bytes of encrypted data: string(344) "EhJiMGQK6qjp/wE4KXmJopBA82ylNxthg[...]o/Xg==" So far, so good. $ php openssl.php 246 ---> Get public key from my.cert: resource(5) of type (OpenSSL key) ---> Encrypt 246 bytes of data using public key: bool(false) ---> Freeing public key: NULL *** Encryption failed! Tested with PHP versions: $ php -v PHP 4.3.4 (cli) (built: Nov 21 2003 00:21:18) Copyright (c) 1997-2003 The PHP Group Zend Engine v1.3.0, Copyright (c) 1998-2003 Zend Technologies and $ php-dev -v PHP 5.0.0RC1-dev (cli) (built: Jan 18 2004 16:53:16) (DEBUG) Copyright (c) 1997-2004 The PHP Group Zend Engine v2.0.0-dev, Copyright (c) 1998-2004 Zend Technologies on the following platforms $ uname -a FreeBSD friebes.net 4.8-STABLE FreeBSD 4.8-STABLE #9: Thu Aug 7 21:39:07 CEST 2003 [EMAIL PROTECTED]:/usr/obj/usr/src/sys/GENERIC i386 $ pkg_info |grep openssl openssl-0.9.7b_1 SSL and crypto library and $ uname -a Linux heuer1 2.2.20 #1 SMP Mon Nov 5 14:36:30 CET 2001 i686 unknown $ dpkg -l | grep openssl ii openssl 0.9.6c-2.woody Secure Socket Layer (SSL) binary and related / Timm
openssl.php
Description: application/php
-- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php