84669 人が学習中
152542 人が学習中
20005 人が学習中
5487 人が学習中
7821 人が学習中
359900 人が学習中
3350 人が学習中
180660 人が学習中
48569 人が学習中
18603 人が学習中
40936 人が学習中
1549 人が学習中
1183 人が学習中
32909 人が学習中
1.现在我需要开发通用平台(mac,windows)的桌面程序,但是程序需要涉及到前端大文件(百兆左右)加密功能。我们知道node.js做计算密集型性能是很差的,那nw.js计算性能是否也很差?
拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...
我不清楚计算性能具体如何,实在没做过这么牛逼的事情。不过既然你说nodejs处理计算密集型任务不合适,那么我想nw也一样了,不信你看:
nodejs
nw
nw.js集成的就是nodejs
nw.js
你可以先试试 atom/vscode 打开百兆文件,他们是基于 electron,跟 nw 一样的。坏消息是 node 一次只能载入1.4G文件,好消息是node的模块可以用 C/C++ 来写。底层的东西我不是很懂,只能提供这些信息了。
只要各个功能设计为分离开执行,我觉得应该没有什么问题.打个比方,我在本地启动一个单进程HTTP服务器然后调用系统浏览器访问.php -S 127.0.0.1:8080 -t /wwwServer和Client是分离开发的,就算Server卡住了,Client里的JS还是可以运行的.对于加密100MB左右的文件,肯定不能让Server和Client卡住,这时可以考虑本地Server端proc_open异步打开一个进程来执行耗时的加密操作,浏览器端通过JS间隔10秒轮询来获知任务进度.NW.js我没用过,但思路差不多.
php -S 127.0.0.1:8080 -t /www
我在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"; }
我不清楚计算性能具体如何,实在没做过这么牛逼的事情。不过既然你说
nodejs
处理计算密集型任务不合适,那么我想nw
也一样了,不信你看:你可以先试试 atom/vscode 打开百兆文件,他们是基于 electron,跟 nw 一样的。
坏消息是 node 一次只能载入1.4G文件,好消息是node的模块可以用 C/C++ 来写。
底层的东西我不是很懂,只能提供这些信息了。
只要各个功能设计为分离开执行,我觉得应该没有什么问题.
打个比方,我在本地启动一个单进程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.