mcrypt性能

Ian*_*ood 6 php linux mcrypt

我正在加密一些数据,并在系统之间的srcipt运行时间中获得截然不同的结果.

在win7机器上运行我的算法,加密在3-8千秒内完成.

linux上的相同代码(ubuntu11和debian6盒子)需要7到35个SECONDS.

这对我的需求来说并不是真的可以接受,并且想知道是否有任何善良的人可以放弃任何光明.

相关代码如下:

<?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;
    }
}
Run Code Online (Sandbox Code Playgroud)

运行此代码是我看到差异的地方:

<?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;
Run Code Online (Sandbox Code Playgroud)

任何指针都将非常感激...

Ian*_*ood 6

找到解决方案!!

有点奇怪,但我明白为什么会这样.

它是用于基于MCRYPT_DEV_RANDOM生成随机数据的方法.

答案(或者至少对我有用的东西)在于本文

短篇小说改为使用MCRYPT_DEV_URANDOM.

*nix上的MCRYPT_DEV_RANDOM会阻塞,直到熵池中有足够的数据可用.如果没有,URANDOM就会拥有它.