summaryrefslogtreecommitdiff
path: root/ext/openssl/tests/bug71917.phpt
blob: a68cf0162c882f99d470f9b5ab61b746e33ed915 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
--TEST--
Bug #71917: openssl_open() returns junk on envelope < 16 bytes
--SKIPIF--
<?php
if (!extension_loaded("openssl")) die("skip openssl not loaded");
?>
--FILE--
<?php
function test($envkey) {
    $publicKey = "file://" . __DIR__ . "/public.key";
    $privateKey = "file://" . __DIR__ . "/private_rsa_1024.key";
    openssl_public_encrypt($envkey, $envelope, $publicKey);
    $sealed = openssl_encrypt(
        'plaintext',
        'rc4', $envkey,
        OPENSSL_RAW_DATA | OPENSSL_DONT_ZERO_PAD_KEY
    );
    openssl_open($sealed, $output, $envelope, $privateKey, 'rc4');
    var_dump($output === 'plaintext');
}

// works - key of 16 bytes
test('1234567890123456i');
// fails - key of 15 bytes
test('123456789012345');
?>
--EXPECT--
bool(true)
bool(true)