2014-09-04 4 views
1

Я работал над моим проектом expressjs, но теперь я столкнулся с тупиком. Мне нужно зашифровать строку с определенным модулем и экспонентой. Вероятно, я должен упомянуть, что я действительно мало знаю о криптографии.Использование открытого ключа RSA для шифрования строки

Так, например, у меня есть эти:

var mod = "99F496606F25ABC3FB26D21D58B1B9D7714B016E870B57EB3220DD60B55796A2E6A3CE65C59CCAD42AE8DCBD475125BF031DA2A66DAE0C5CBF5E5C445B89FE13C879D519FC9603C337226D23E230C986D6E057214A309BF7B954C899FF920690A8558056D95E69F932CF1BDAA55E90D871040C614D7CDB496741E16B8728F6E5B3CE9A39D76F0BF1E5CF244DC4B88117B4F45A48C103CEE5CCEE3E227B0C1D6DDB24E9FC140A05A4C6E094CA0D9512379964B0C1000F9E94F7071BE7F0B04178FE6B60222FA4896D5D7F4AECE29D83AD1167A0AE023C1B9F29265B290E695913D83E965335364014BB227284A6D2A825CE4A3D839431546CA6BEA98691E53CE9"; 
var exponent = "010001"; 

И если я правильно понял, я теперь нужно создать открытый ключ с этим? Я просмотрел множество модулей nodejs для шифрования rsa, но все они, похоже, требуют, чтобы ключ находился в формате PEM. Так что я нашел этот thread и использовал его как это:

rsaPublicKeyPem(new Buffer(mod).toString('base64'), new Buffer(exponent).toString('base64')); 

Который дал мне это:

-----BEGIN RSA PUBLIC KEY----- 
MIICDAKCAgA5OUY0OTY2MDZGMjVBQkMzRkIyNkQyMUQ1OEIxQjlENzcxNEIwMTZF 
ODcwQjU3RUIzMjIwREQ2MEI1NTc5NkEyRTZBM0NFNjVDNTlDQ0FENDJBRThEQ0JE 
NDc1MTI1QkYwMzFEQTJBNjZEQUUwQzVDQkY1RTVDNDQ1Qjg5RkUxM0M4NzlENTE5 
RkM5NjAzQzMzNzIyNkQyM0UyMzBDOTg2RDZFMDU3MjE0QTMwOUJGN0I5NTRDODk5 
RkY5MjA2OTBBODU1ODA1NkQ5NUU2OUY5MzJDRjFCREFBNTVFOTBEODcxMDQwQzYx 
NEQ3Q0RCNDk2NzQxRTE2Qjg3MjhGNkU1QjNDRTlBMzlENzZGMEJGMUU1Q0YyNDRE 
QzRCODgxMTdCNEY0NUE0OEMxMDNDRUU1Q0NFRTNFMjI3QjBDMUQ2RERCMjRFOUZD 
nMTQwQTA1QTRDNkUwOTRDQTBEOTUxMjM3OTk2NEIwQzEwMDBGOUU5NEY3MDcxQkU3 
RjBCMDQxNzhGRTZCNjAyMjJGQTQ4OTZENUQ3RjRBRUNFMjlEODNBRDExNjdBMEFF 
MDIzQzFCOUYyOTI2NUIyOTBFNjk1OTEzRDgzRTk2NTMzNTM2NDAxNEJCMjI3Mjg0 
QTZEMkE4MjVDRTRBM0Q4Mzk0MzE1NDZDQTZCRUE5ODY5MUU1M0NFOQIGMDEwMDAx 
-----END RSA PUBLIC KEY----- 

Что я тогда пытался использовать с ursa library

var key = ursa.createPublicKey(pem); 

Но он говорит, что это не публичный ключ. Я также попытался использовать его с node-rsa, но получил почти такую ​​же ошибку:/

Любые идеи, что я сделал неправильно здесь или альтернативные методы?

Спасибо, очень ценю!

+2

Пожалуйста, всегда включайте полное сообщение об ошибке, я не думаю, что оно действительно говорило с вами? –

ответ

0

Формат PEM представляет собой версию формата DER, кодированную Base64. Вы можете использовать OpenSSL, чтобы помочь вам создать DER, а затем вывести PEM. Я дал this answer на другой вопрос, в котором есть некоторый код Ruby, который выводит файл в формате PEM, заданный только модулем и показателем. Это должно привести вас к решению.

Смежные вопросы