首页  >  问答  >  正文

node.js - 求问nw.js开发桌面版,其js计算性能如何?

1.现在我需要开发通用平台(mac,windows)的桌面程序,但是程序需要涉及到前端大文件(百兆左右)加密功能。我们知道node.js做计算密集型性能是很差的,那nw.js计算性能是否也很差?

高洛峰高洛峰2764 天前799

全部回复(3)我来回复

  • 迷茫

    迷茫2017-04-17 14:53:41

    我不清楚计算性能具体如何,实在没做过这么牛逼的事情。不过既然你说nodejs处理计算密集型任务不合适,那么我想nw也一样了,不信你看:

    nw.js集成的就是nodejs

    回复
    0
  • 天蓬老师

    天蓬老师2017-04-17 14:53:41

    你可以先试试 atom/vscode 打开百兆文件,他们是基于 electron,跟 nw 一样的。
    坏消息是 node 一次只能载入1.4G文件,好消息是node的模块可以用 C/C++ 来写。
    底层的东西我不是很懂,只能提供这些信息了。

    回复
    0
  • 迷茫

    迷茫2017-04-17 14:53:41

    只要各个功能设计为分离开执行,我觉得应该没有什么问题.
    打个比方,我在本地启动一个单进程HTTP服务器然后调用系统浏览器访问.
    php -S 127.0.0.1:8080 -t /www
    Server和Client是分离开发的,就算Server卡住了,Client里的JS还是可以运行的.
    对于加密100MB左右的文件,肯定不能让Server和Client卡住,
    这时可以考虑本地Server端proc_open异步打开一个进程来执行耗时的加密操作,
    浏览器端通过JS间隔10秒轮询来获知任务进度.
    NW.js我没用过,但思路差不多.

    我在Ubuntu(i5-3230)上用PHP7的mcrypt_blowfish加解密10MB数据,耗时不到0.2秒,内存占用约40MB.

    <?php
    header('Content-Type: text/plain;charset=utf-8');
    
    // 加密数据 mcrypt_generic
    // 解密数据 mdecrypt_generic
    // http://php.net/manual/zh/function.mdecrypt-generic.php
    // 加密描述符 $td
    // 密钥 $key
    // 初始向量 $iv
    
    /* 数据 */
    $key = 'a39d0d0e2e8c360205d105f9edcc51fdf5a780ce'; // sha1( uniqid(getmypid().'_'.mt_rand().'_', true) )
    $plain_text = file_get_contents('/home/eechen/note/file.txt');
    
    /* 打开加密模块,并且创建初始向量 */
    //打开算法和模式对应的模块,成功则返回加密描述符(资源类型),发生错误则返回FALSE.
    //算法类型MCRYPT_BLOWFISH,模式MCRYPT_MODE_ECB
    $td = mcrypt_module_open(MCRYPT_BLOWFISH, '', MCRYPT_MODE_ECB, '');
    $key = substr($key, 0, mcrypt_enc_get_key_size($td));
    $iv_size = mcrypt_enc_get_iv_size($td);
    $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
    $starttime = microtime(true);
    /* 初始化加密句柄 */
    if (mcrypt_generic_init($td, $key, $iv) != -1) {
    
        /* 加密数据 */
        $c_t = mcrypt_generic($td, $plain_text);
        mcrypt_generic_deinit($td);
        // 密文是二进制数据
        //echo '密文: '.bin2hex($c_t)."\n";
    
        /* 为解密重新初始化缓冲区 */
        mcrypt_generic_init($td, $key, $iv);
        $p_t = mdecrypt_generic($td, $c_t);
        // 解密数据,请注意,由于存在数据补齐的情况,返回的字符串的长度可能和明文的长度不相等.
        //echo '明文: '.$p_t."\n";
        /* 执行清理工作 */
        mcrypt_generic_deinit($td);
        mcrypt_module_close($td);
    }
    echo microtime(true) - $starttime."\n";
    if (strncmp($p_t, $plain_text, strlen($plain_text)) == 0) {
        echo "OK\n";
    } else {
        echo "Error\n";
    }
    

    回复
    0
  • 取消回复