【问题标题】:TripleDES Encryption result different in C# and Node JSTripleDES 加密结果在 C# 和 Node JS 中不同
【发布时间】:2019-01-25 13:07:06
【问题描述】:

这可能是重复的,但我无法修复它。 下面是我在 C# 中为 TripleDES 编写的代码:

using System;
using System.Security.Cryptography;
using System.IO;
using System.Text;

class MainClass {
   public static void Main (string[] args) {

   String encrypt="5241110000602040";
   SymmetricAlgorithm sa= SymmetricAlgorithm.Create("TripleDES");
   sa.Key= Convert.FromBase64String("FRSF1P3b6fHiW/DXrK8ZJks5KAiyNpP0");
   sa.IV=Convert.FromBase64String("YFKA0QlomKY=");


   byte[] iba=Encoding.ASCII.GetBytes(encrypt);
   MemoryStream mS=new MemoryStream();

   ICryptoTransform trans=sa.CreateEncryptor();
   byte[] buf= new byte[2049];

   CryptoStream cs=new CryptoStream(mS,trans,CryptoStreamMode.Write);

   cs.Write(iba,0,iba.Length);
   cs.FlushFinalBlock();

   Console.WriteLine(Convert.ToBase64String(mS.ToArray()));


 }
}

加密后的值为

Nj7GeyrbJB93HZLplFZwq5HRjxnvZSvU

我想用 nodejs 的 crypto-js 库实现同样的目的。这是我尝试过的nodejs代码:

var CryptoJS = require("crypto-js");

var text = "5241110000602040";
var key = "FRSF1P3b6fHiW/DXrK8ZJks5KAiyNpP0";

var options = {
//  mode: CryptoJS.mode.ECB, 
//  padding: CryptoJS.pad.Pkcs7,
iv: CryptoJS.enc.Hex.parse("YFKA0QlomKY=")
};

var textWordArray = CryptoJS.enc.Utf8.parse(text);
var keyHex = CryptoJS.enc.Hex.parse(key);

var encrypted = CryptoJS.TripleDES.encrypt(textWordArray, keyHex, options);

var base64String = encrypted.toString();

console.log('encrypted val: ' + base64String);

预期输出

Nj7GeyrbJB93HZLplFZwq5HRjxnvZSvU

实际输出

NXSBe9YEiGs5p6VHkzezfdcb5o08bALB

nodejs 中的加密值与 C# 不同。我做错了什么?

【问题讨论】:

  • 两种语言是否以相同的键和 IV 结束?你应该先检查一下。
  • CryptoJS.enc.Hex.parse("YFKA0QlomKY=") 不应该工作 - 这不是十六进制字符串,它是 Base64。 (因此,毫不奇怪,CryptoJS.enc.Base64.parse)。
  • @JeroenMostert 试过了,但加密的输出仍然不同

标签: c# node.js cryptojs tripledes


【解决方案1】:

您以不同的方式解码密钥和 iv。

在c#中你使用base64:

sa.Key= Convert.FromBase64String("FRSF1P3b6fHiW/DXrK8ZJks5KAiyNpP0");
sa.IV=Convert.FromBase64String("YFKA0QlomKY=");

在 node.js 十六进制中:

iv: CryptoJS.enc.Hex.parse("YFKA0QlomKY=")
var key = "FRSF1P3b6fHiW/DXrK8ZJks5KAiyNpP0";
var keyHex = CryptoJS.enc.Hex.parse(key);

在这两种情况下都尝试使用 base64。

【讨论】:

    猜你喜欢
    • 2011-01-28
    • 2020-10-08
    • 2014-07-07
    • 2016-02-19
    • 1970-01-01
    • 2020-02-25
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多