dongsaoshuo4326 2014-10-07 10:14
浏览 16
已采纳

mcrypt很长时间初始化模块

I have a class which has following __construct.

final class mydecoder {
    private $td;
    public function __construct($key){
        /* Open the cipher */
        $this->td = mcrypt_module_open(MCRYPT_BLOWFISH, '', 'ecb', '');
        /* Create the IV and determine the keysize length, use MCRYPT_RAND
        * on Windows instead */
        $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($this->td), MCRYPT_DEV_RANDOM);
        $ks = mcrypt_enc_get_key_size($this->td);
        /* Create key */
        $key = substr(md5($key), 0, $ks);
        /* Intialize encryption */
        mcrypt_generic_init($this->td, $key, $iv);
    }
}

When I call it like:

$encoder = new myfish('mykey1');
$encoder = new myfish('mykey2');

I have following problems.

Opening page for first time

construct #1 execution time: 5s
construct #2 execution time: 0s

Pressing F5

construct #1 execution time: 0s
construct #2 execution time: 14s

Pressing F5

construct #1 execution time: 5s
construct #2 execution time: 14s

Mashing F5 for 3 times (to queue)

construct #1 execution time: 15s
construct #2 execution time: 45s

It looks like it queues? How does it work? Maybe I'm not using it properly? I don't have much experience with cryptography since I never needed it before :)

  • 写回答

1条回答 默认 最新

  • douba9776 2014-10-07 10:20
    关注

    The problem is caused by the initialising vector (IV) genertor, i.e. this line:

    $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($this->td), MCRYPT_DEV_RANDOM);
    

    If you use MCRYPT_DEV_RANDOM mode, PHP will wait until there is enough entropy to be secure.

    However, if you change the mode to MCRYPT_DEV_URANDOM (it will be less secure) but it wont wait if entropy gets too low, thus improving the speed.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行