Je dois générer deux clés (privée et publique) pour chiffrer un texte avec le public et laisser l'utilisateur avec la clé privée déchiffrer le texte.
Est-ce possible avec le module Crypto ?
Je dois générer deux clés (privée et publique) pour chiffrer un texte avec le public et laisser l'utilisateur avec la clé privée déchiffrer le texte.
Est-ce possible avec le module Crypto ?
nodejs v10.12 prend désormais en charge cela nativement avec crypto.generateKeyPair
const { generateKeyPair } = require('crypto');
generateKeyPair('rsa', {
modulusLength: 4096,
publicKeyEncoding: {
type: 'spki',
format: 'pem'
},
privateKeyEncoding: {
type: 'pkcs8',
format: 'pem',
cipher: 'aes-256-cbc',
passphrase: 'top secret'
}
}, (err, publicKey, privateKey) => {
// Handle errors and use the generated key pair.
});
Utilisez le module crypto de npm pour générer KeyPair.
var crypto = require('crypto');
var prime_length = 60;
var diffHell = crypto.createDiffieHellman(prime_length);
diffHell.generateKeys('base64');
console.log("Public Key : " ,diffHell.getPublicKey('base64'));
console.log("Private Key : " ,diffHell.getPrivateKey('base64'));
console.log("Public Key : " ,diffHell.getPublicKey('hex'));
console.log("Private Key : " ,diffHell.getPrivateKey('hex'));
Ci-dessus, un exemple d'extrait. Pour en savoir plus sur la documentation de paiement http://nodejs.org/api/crypto.html
Si vous savez comment obtenir ce que vous voulez d'OpenSSL, je pense qu'il est parfaitement raisonnable d'exécuter OpenSSL en utilisant child_process
Node.
var cp = require('child_process')
, assert = require('assert')
;
var privateKey, publicKey;
publicKey = '';
cp.exec('openssl genrsa 2048', function(err, stdout, stderr) {
assert.ok(!err);
privateKey = stdout;
console.log(privateKey);
makepub = cp.spawn('openssl', ['rsa', '-pubout']);
makepub.on('exit', function(code) {
assert.equal(code, 0);
console.log(publicKey);
});
makepub.stdout.on('data', function(data) {
publicKey += data;
});
makepub.stdout.setEncoding('ascii');
makepub.stdin.write(privateKey);
makepub.stdin.end();
});
Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.