2008-07-19 07:52:01 +08:00
|
|
|
--TEST--
|
2016-02-04 00:20:27 +08:00
|
|
|
openssl_decrypt() tests dependent on openssl_encrypt
|
2008-07-19 07:52:01 +08:00
|
|
|
--SKIPIF--
|
|
|
|
<?php if (!extension_loaded("openssl")) print "skip"; ?>
|
|
|
|
--FILE--
|
|
|
|
<?php
|
|
|
|
$data = "openssl_encrypt() and openssl_decrypt() tests";
|
|
|
|
$method = "AES-128-CBC";
|
|
|
|
$password = "openssl";
|
|
|
|
|
2010-05-20 04:05:09 +08:00
|
|
|
$ivlen = openssl_cipher_iv_length($method);
|
|
|
|
$iv = '';
|
|
|
|
srand(time() + ((microtime(true) * 1000000) % 1000000));
|
|
|
|
while(strlen($iv) < $ivlen) $iv .= chr(rand(0,255));
|
|
|
|
|
2011-05-21 02:56:13 +08:00
|
|
|
$encrypted = openssl_encrypt($data, $method, $password, 0, $iv);
|
|
|
|
$output = openssl_decrypt($encrypted, $method, $password, 0, $iv);
|
2008-07-19 07:52:01 +08:00
|
|
|
var_dump($output);
|
2011-05-21 02:56:13 +08:00
|
|
|
$encrypted = openssl_encrypt($data, $method, $password, OPENSSL_RAW_DATA, $iv);
|
|
|
|
$output = openssl_decrypt($encrypted, $method, $password, OPENSSL_RAW_DATA, $iv);
|
2008-07-19 07:52:01 +08:00
|
|
|
var_dump($output);
|
2011-05-21 02:56:13 +08:00
|
|
|
// if we want to manage our own padding
|
|
|
|
$padded_data = $data . str_repeat(' ', 16 - (strlen($data) % 16));
|
|
|
|
$encrypted = openssl_encrypt($padded_data, $method, $password, OPENSSL_RAW_DATA|OPENSSL_ZERO_PADDING, $iv);
|
|
|
|
$output = openssl_decrypt($encrypted, $method, $password, OPENSSL_RAW_DATA|OPENSSL_ZERO_PADDING, $iv);
|
|
|
|
var_dump(rtrim($output));
|
2017-06-26 01:08:50 +08:00
|
|
|
// if we want to prefer variable length cipher setting
|
|
|
|
$encrypted = openssl_encrypt($data, "bf-ecb", $password, OPENSSL_DONT_ZERO_PAD_KEY);
|
|
|
|
$output = openssl_decrypt($encrypted, "bf-ecb", $password, OPENSSL_DONT_ZERO_PAD_KEY);
|
|
|
|
var_dump($output);
|
2008-07-19 07:52:01 +08:00
|
|
|
?>
|
|
|
|
--EXPECT--
|
|
|
|
string(45) "openssl_encrypt() and openssl_decrypt() tests"
|
|
|
|
string(45) "openssl_encrypt() and openssl_decrypt() tests"
|
2011-05-21 02:56:13 +08:00
|
|
|
string(45) "openssl_encrypt() and openssl_decrypt() tests"
|
2017-06-26 01:08:50 +08:00
|
|
|
string(45) "openssl_encrypt() and openssl_decrypt() tests"
|