Nodejs和Ruby中的加密

时间:2015-11-26 02:35:54

标签: ruby-on-rails ruby node.js cryptography node-crypto

我想加密一个字符串并传递给Rails应用程序,所以我在Nodejs和Ruby中都找到了加密库。

在Nodejs中:

var crypto = require('crypto'),
    algorithm = 'aes-256-ctr',
    password = 'd6F3Efeqd6F3Efeqd6F3Efeqd6F3Efeq';

function encrypt(text){
  var cipher = crypto.createCipher(algorithm,password)
  var crypted = cipher.update(text,'ascii',"base64")
  crypted += cipher.final("base64");
  return crypted;
}

结果是:

encrypt("1") //-输出 2g==

在Ruby中

def encrypt(des_text)
    des = OpenSSL::Cipher::Cipher.new('aes-256-ctr')
    des.encrypt
    des.key = 'd6F3Efeqd6F3Efeqd6F3Efeqd6F3Efeq'
    result = des.update(des_text)
    result << des.final
    return Base64.encode64 result
end

结果是:

encrypt("1")  # 输出 1A==

所以我使用相同的方式和密钥加密相同的字符串,为什么结果不一样?

1 个答案:

答案 0 :(得分:2)

crypto.createCipher(算法,密码)和crypto.createCipheriv(算法,密钥,iv)之间的区别在于密码用于派生密钥和IV。

var crypto = require('crypto'),
    algorithm = 'aes-256-ctr',
    key = 'd6F3Efeqd6F3Efeqd6F3Efeqd6F3Efeq',
    iv = "1234567890123456";

function encrypt(text){
  var cipher = crypto.createCipheriv(algorithm,key,iv)
  var crypted = cipher.update(text,'utf-8',"base64")
  crypted += cipher.final("base64");
  return crypted;
}

console.log(encrypt("1")); // return bQ==

在Ruby中,如果你没有指定iv,那么它将使用默认的iv。

require 'openssl'
require 'base64'

def encrypt(des_text)
    des = OpenSSL::Cipher::Cipher.new('aes-256-ctr')
    des.encrypt
    des.key = 'd6F3Efeqd6F3Efeqd6F3Efeqd6F3Efeq'
    des.iv = "1234567890123456"
    result = des.update(des_text)
    result << des.final
    return Base64.encode64 result
end

p encrypt("1").strip # return bQ==