1.现在我需要开发通用平台(mac,windows)的桌面程序,但是程序需要涉及到前端大文件(百兆左右)加密功能。我们知道node.js做计算密集型性能是很差的,那nw.js计算性能是否也很差?
迷茫2017-04-17 14:53:41
我不清楚計算性能具體如何,實在沒做過這麼屌的事情。不過既然你說nodejs
處理運算密集型任務不合適,那我想nw
也一樣了,不信你看:
nw.js
整合的就是nodejs
天蓬老师2017-04-17 14:53:41
你可以先試試 atom/vscode 開啟百兆文件,他們是基於 electron,跟 nw 一樣的。
壞消息是 node 一次只能載入1.4G文件,好消息是node的模組可以用 C/C++ 來寫。
底層的東西我不是很懂,只能提供這些資訊了。
迷茫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";
}