производительность mcrypt - PullRequest
       11

производительность mcrypt

6 голосов
/ 14 февраля 2012

Я шифрую некоторые данные и получаю очень разные результаты во время выполнения srcipt между системами.

При выполнении моего алгоритма на машине win7 шифрование завершается за 3-8 тысяч секунд.

Один и тот же код в linux (в коробках ubuntu11 и debian6) занимает от 7 до 35 секунд.

Это не совсем приемлемо для моих нужд, и мне было интересно, может ли какой-нибудь добрый человек пролить свет.

Соответствующий код ниже:

<?php

class MyEncryption
{
    public function __construct( $keyData )
    {
        $this->_encryptInit( $keyData );
    }

    private function _encryptInit( $keyData )
    {
        $this->ch = mcrypt_module_open('rijndael-256', '', MCRYPT_MODE_ECB , '');

        $vector  = mcrypt_create_iv (mcrypt_enc_get_iv_size( $this->ch ), MCRYPT_DEV_RANDOM );
        $keySize = mcrypt_enc_get_key_size( $this->ch );

        $key = substr( hash('SHA512', $keyData . $keySize ), 0, $keySize );

        mcrypt_generic_init( $this->ch, $key, $vector );
    }

    private function _encryptClose()
    {
        mcrypt_generic_deinit( $this->ch );
        mcrypt_module_close( $this->ch );
    }

    public function encryptData( $data )
    {
        $safeData = mcrypt_generic( $this->ch, $data );

        $this->_encryptClose();

        return $safeData;
    }

    public function decryptData( $safeData )
    {
        $data =  mdecrypt_generic( $this->ch, $safeData );

        $this->_encryptClose();

        return $data;
    }
}

при запуске этого кода я вижу расхождения:

<?php

echo microtime(). ' -- Start || '.PHP_EOL;
$enc = new MyEncryption( 'astring' );
echo microtime(). ' -- Init || '.PHP_EOL;
$data = array( 'dob'=>'1970-01-01','creditcardno'=>'4000123412345678' );
$safeData = $enc->encryptData( json_encode( $data ) );
echo microtime(). ' -- Encrypted || '.PHP_EOL;
echo ' == ' . $safeData . ' == '.PHP_EOL;

$dec = new MyEncryption( 'astring' );
echo microtime(). ' -- Init2 || '.PHP_EOL;
$data = json_decode( $dec->decryptData( trim( $safeData ) ) );
echo microtime(). ' -- Decrypted || '.PHP_EOL;
echo ' == ' . $data . ' == '.PHP_EOL;

Любые указатели будут с благодарностью приветствовать ..

1 Ответ

6 голосов
/ 14 февраля 2012

Нашли решение !!

Немного странно, но я понимаю, почему это так.

Это метод, используемый для генерации случайных данных на основе MCRYPT_DEV_RANDOM.

ответ (или хотя бы то, что у меня сработало) лежит в этой статье

Короткая история вместо этого использует MCRYPT_DEV_URANDOM.

MCRYPT_DEV_RANDOM для * nix блоков до тех пор, пока в пуле энтропии не будет достаточно данных. URANDOM делает его самостоятельно, если его нет.

...