使用 npm `threads` 模块生成 Diffie Hellman 对象:getPrime 未定义
Generate Diffie Hellman Object using npm `threads` module: getPrime is undefined
使用 npm threads
库我尝试使用单独的线程而不是主线程以非阻塞方式创建 diffie hellman:
const spawn = require('threads').spawn;
const thread = spawn(function(input, done) {
const cryptot = require('crypto');
const dh = cryptot.createDiffieHellman(2048);
done({dh});
});
thread.send({p:null, g:null}).on('message', (response) => {
console.log(response.dh.getPrime(), response.dh.getGenerator());
thread.kill();
}).on('error', (err)=>{
console.error(err);
}).on('exit', function() {
console.log('Worker has been terminated.');
});
但我收到以下错误:
/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/dummy_src/thread_dh.js:10
console.log(response.dh.getPrime(), response.dh.getGenerator());
^
TypeError: response.dh.getPrime is not a function
at Worker.thread.send.on (/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/dummy_src/thread_dh.js:10:27)
at Worker.emit (/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/node_modules/eventemitter3/index.js:129:35)
at Worker.handleMessage (/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/node_modules/threads/lib/worker.node/worker.js:148:17)
at ChildProcess.emit (events.js:182:13)
at emit (internal/child_process.js:812:12)
你知道为什么收到的 dh
对象不包含方法 getPrime
并且通过假设也包含 getGenerator
吗?
确实,如果不提供生成器和素数,密钥生成在 node.js 中提供的实现中会很慢。但让它变慢的是创建正确的素数和生成器,其中素数将是 2048 位。
因此您可以执行以下操作:
- 生成素数和生成器inside线程
- 通过 done 回调将素数 abd 生成器传递给
message
事件
- 用生成的素数和生成器在那里重新创建一个 diffie-hellman 对象。
这些步骤将由此代码产生:
const spawn = require('threads').spawn;
const thread = spawn(function(input, done) {
const cryptot = require('crypto');
console.time('dh-thread');
const dh = cryptot.createDiffieHellman(2048);
console.timeEnd('dh-thread');
done({prime: dh.getPrime().toString('hex'), generator: dh.getGenerator().toString('hex')});
});
thread.send({p:null, g:null}).on('message', (response) => {
const cryptot = require('crypto');
const dh = cryptot.createDiffieHellman(response.prime, response.generator);
// Do whatever you want there
thread.kill();
}).on('error', (err)=>{
console.error(err);
}).on('exit', function() {
console.log('Worker has been terminated.');
});
另外,为了证明我上面的陈述是正确的,让我使用计时器稍微修改一下代码:
const spawn = require('threads').spawn;
const thread = spawn(function(input, done) {
const cryptot = require('crypto');
console.time('dh-thread');
const dh = cryptot.createDiffieHellman(2048);
console.timeEnd('dh-thread');
done({prime: dh.getPrime().toString('hex'), generator: dh.getGenerator().toString('hex')});
});
thread.send({p:null, g:null}).on('message', (response) => {
console.time('dh');
const cryptot = require('crypto');
const dh = cryptot.createDiffieHellman(response.prime, response.generator);
console.timeEnd('dh');
thread.kill();
}).on('error', (err)=>{
console.error(err);
}).on('exit', function() {
console.log('Worker has been terminated.');
});
以上代码的执行结果:
dh-thread: 12815.747ms
dh: 6.733ms
Worker has been terminated.
如您所见,没有素数和生成器的 diffie hellman 生成需要 WAY 太长,而不是提供素数和生成器。
使用 npm threads
库我尝试使用单独的线程而不是主线程以非阻塞方式创建 diffie hellman:
const spawn = require('threads').spawn;
const thread = spawn(function(input, done) {
const cryptot = require('crypto');
const dh = cryptot.createDiffieHellman(2048);
done({dh});
});
thread.send({p:null, g:null}).on('message', (response) => {
console.log(response.dh.getPrime(), response.dh.getGenerator());
thread.kill();
}).on('error', (err)=>{
console.error(err);
}).on('exit', function() {
console.log('Worker has been terminated.');
});
但我收到以下错误:
/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/dummy_src/thread_dh.js:10
console.log(response.dh.getPrime(), response.dh.getGenerator());
^
TypeError: response.dh.getPrime is not a function
at Worker.thread.send.on (/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/dummy_src/thread_dh.js:10:27)
at Worker.emit (/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/node_modules/eventemitter3/index.js:129:35)
at Worker.handleMessage (/home/pcmagas/Kwdikas/master_thesis/custom_xmpp/node_modules/threads/lib/worker.node/worker.js:148:17)
at ChildProcess.emit (events.js:182:13)
at emit (internal/child_process.js:812:12)
你知道为什么收到的 dh
对象不包含方法 getPrime
并且通过假设也包含 getGenerator
吗?
确实,如果不提供生成器和素数,密钥生成在 node.js 中提供的实现中会很慢。但让它变慢的是创建正确的素数和生成器,其中素数将是 2048 位。
因此您可以执行以下操作:
- 生成素数和生成器inside线程
- 通过 done 回调将素数 abd 生成器传递给
message
事件 - 用生成的素数和生成器在那里重新创建一个 diffie-hellman 对象。
这些步骤将由此代码产生:
const spawn = require('threads').spawn;
const thread = spawn(function(input, done) {
const cryptot = require('crypto');
console.time('dh-thread');
const dh = cryptot.createDiffieHellman(2048);
console.timeEnd('dh-thread');
done({prime: dh.getPrime().toString('hex'), generator: dh.getGenerator().toString('hex')});
});
thread.send({p:null, g:null}).on('message', (response) => {
const cryptot = require('crypto');
const dh = cryptot.createDiffieHellman(response.prime, response.generator);
// Do whatever you want there
thread.kill();
}).on('error', (err)=>{
console.error(err);
}).on('exit', function() {
console.log('Worker has been terminated.');
});
另外,为了证明我上面的陈述是正确的,让我使用计时器稍微修改一下代码:
const spawn = require('threads').spawn;
const thread = spawn(function(input, done) {
const cryptot = require('crypto');
console.time('dh-thread');
const dh = cryptot.createDiffieHellman(2048);
console.timeEnd('dh-thread');
done({prime: dh.getPrime().toString('hex'), generator: dh.getGenerator().toString('hex')});
});
thread.send({p:null, g:null}).on('message', (response) => {
console.time('dh');
const cryptot = require('crypto');
const dh = cryptot.createDiffieHellman(response.prime, response.generator);
console.timeEnd('dh');
thread.kill();
}).on('error', (err)=>{
console.error(err);
}).on('exit', function() {
console.log('Worker has been terminated.');
});
以上代码的执行结果:
dh-thread: 12815.747ms
dh: 6.733ms
Worker has been terminated.
如您所见,没有素数和生成器的 diffie hellman 生成需要 WAY 太长,而不是提供素数和生成器。