`

(转)nodejs和java中的des/3des加密解密

des 
阅读更多
Java和nodejs中des加解密数据互操作,直接上代码(仅供参考):

var assert = require('assert');
var crypto = require('crypto');

function test_des(param) {
	var key = new Buffer(param.key);
	var iv = new Buffer(param.iv ? param.iv : 0)
	var plaintext = param.plaintext
	var alg = param.alg
	var autoPad = param.autoPad
	
	//encrypt
	var cipher = crypto.createCipheriv(alg, key, iv);
	cipher.setAutoPadding(autoPad)	//default true
	var ciph = cipher.update(plaintext, 'utf8', 'hex');
	ciph += cipher.final('hex');
	console.log(alg, ciph)

	//decrypt
	var decipher = crypto.createDecipheriv(alg, key, iv);
	cipher.setAutoPadding(autoPad)
	var txt = decipher.update(ciph, 'hex', 'utf8');
	txt += decipher.final('utf8');	  
	assert.equal(txt, plaintext, 'fail');
}

test_des({
	alg: 'des-ecb',
	autoPad: true,
	key: '01234567',
	plaintext: '1234567812345678',
	iv: null
})

test_des({
	alg: 'des-cbc',
	autoPad: true,
	key: '01234567',
	plaintext: '1234567812345678',
	iv: '12345678'
})

test_des({
	alg: 'des-ede3',	//3des-ecb
	autoPad: true,
	key: '0123456789abcd0123456789',
	plaintext: '1234567812345678',
	iv: null
})

test_des({
	alg: 'des-ede3-cbc',	//3des-cbc
	autoPad: true,
	key: '0123456789abcd0123456789',
	plaintext: '1234567812345678',
	iv: '12345678'
})


import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;

import org.apache.commons.codec.binary.Hex;
import org.junit.Test;


	@Test
	public void encrypt_3des_ecb() throws Exception {
		byte[] key = "0123456789abcd0123456789".getBytes();		
		byte[] plainText = "1234567812345678".getBytes();
		
//		KeySpec myKeySpec = new DESedeKeySpec(key);
//		SecretKeyFactory mySecretKeyFactory = SecretKeyFactory.getInstance("DESede");
//		SecretKey secretKey = mySecretKeyFactory.generateSecret(myKeySpec);
		SecretKey secretKey = new SecretKeySpec(key, "DESede");
		//encrypt
		Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
		cipher.init(Cipher.ENCRYPT_MODE, secretKey);
		byte[] encryptedData = cipher.doFinal(plainText);
		System.out.println("encrypt_3des_ecb: " + Hex.encodeHexString(encryptedData));
		
		//decrypt
		cipher.init(Cipher.DECRYPT_MODE, secretKey);
		byte[] decryptPlainText = cipher.doFinal(encryptedData);
		org.junit.Assert.assertArrayEquals(decryptPlainText, plainText);		
	}
	
	@Test
	public void encrypt_3des_cbc() throws Exception {
		byte[] key = "0123456789abcd0123456789".getBytes();		
		byte[] plainText = "1234567812345678".getBytes();
		IvParameterSpec iv = new IvParameterSpec("12345678".getBytes());
		
		SecretKey secretKey = new SecretKeySpec(key, "DESede");
		//encrypt
		Cipher cipher = Cipher.getInstance("DESede/CBC/PKCS5Padding");
		cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);
		byte[] encryptedData = cipher.doFinal(plainText);
		System.out.println("encrypt_3des_cbc: " + Hex.encodeHexString(encryptedData));
		
		//decrypt
		cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
		byte[] decryptPlainText = cipher.doFinal(encryptedData);
		org.junit.Assert.assertArrayEquals(decryptPlainText, plainText);			
	}	

	@Test
	public void encrypt_des_ecb() throws Exception {
		byte[] key = "01234567".getBytes();		
		byte[] plainText = "1234567812345678".getBytes();
		
		SecretKey secretKey = new SecretKeySpec(key, "DES");
		//encrypt
		Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
		cipher.init(Cipher.ENCRYPT_MODE, secretKey);		
		byte[] encryptedData = cipher.doFinal(plainText);
		System.out.println("encrypt_des_ecb: " + Hex.encodeHexString(encryptedData));
		
		//decrypt
		cipher.init(Cipher.DECRYPT_MODE, secretKey);
		byte[] decryptPlainText = cipher.doFinal(encryptedData);
		org.junit.Assert.assertArrayEquals(decryptPlainText, plainText);
	}
	
	@Test
	public void encrypt_des_cbc() throws Exception {
		byte[] key = "01234567".getBytes();		
		byte[] plainText = "1234567812345678".getBytes();
		IvParameterSpec iv = new IvParameterSpec("12345678".getBytes()); 
		
		SecretKey secretKey = new SecretKeySpec(key, "DES");
		//encrypt
		Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
		cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);		
		byte[] encryptedData = cipher.doFinal(plainText);
		System.out.println("encrypt_des_cbc: " + Hex.encodeHexString(encryptedData));
		
		//decrypt
		cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
		byte[] decryptPlainText = cipher.doFinal(encryptedData);
		org.junit.Assert.assertArrayEquals(decryptPlainText, plainText);
	}	



结果:
nodejs 输出结果
des-ecb cb22e0c49a73e0e0cb22e0c49a73e0e008bb5db6b37c06d7
des-cbc 388d44f8b0f709c0915e14abc8eb782604ae07d96110ab0d
des-ede3 0a5f769c1a6eb5710a5f769c1a6eb5713bba29a037c699da
des-ede3-cbc 99988858eabe3e95ace8349b9e19dda66abb82b44b5f8f62

java输出结果
encrypt_des_ecb: cb22e0c49a73e0e0cb22e0c49a73e0e008bb5db6b37c06d7
encrypt_des_cbc: 388d44f8b0f709c0915e14abc8eb782604ae07d96110ab0d
encrypt_3des_ecb: 0a5f769c1a6eb5710a5f769c1a6eb5713bba29a037c699da
encrypt_3des_cbc: 99988858eabe3e95ace8349b9e19dda66abb82b44b5f8f62

(转):http://mygo.iteye.com/blog/2018882
分享到:
评论

相关推荐

    nodejs实现3des(2倍长)加密方式,与DES加密工具一致

    在Node.js中,我们可以使用内置的`crypto`模块来实现DES和3DES加密解密。下面我们将详细介绍如何操作: 1. **引入crypto模块** 首先,我们需要在项目中引入`crypto`模块。在JavaScript文件(如3des.js)中,添加...

    AES加密解密算法C# JAVA nodejs通用

    C# JAVA nodejs通用的AES加密解密算法,考虑到实际使用过程中由于客户端和服务端使用的语言不一样而又需要对数据进行加密和解密的情况,特此总结了C# JAVA nodejs通用的AES加密解密算法,供需要者参考。

    MagicCrypt 是一个Rust 库,用于加密/解密字符串、文件或数据,使用数据加密标准 (DES) 或高级加密标准

    MagicCrypt 是一个 Java/PHP/NodeJS/Rust 库,用于加密/解密字符串、文件或数据,使用数据加密标准 (DES) 或高级加密标准 (AES) 算法。它支持 CBC 分组密码模式、PKCS5 填充和 64、128、192 或 256 位密钥长度。

    使用native方法实现加密解密

    在这个过程中,`JNIEnv`指针用于访问Java对象和方法,`jbyteArray`代表Java的字节数组,我们可以直接在C/C++代码中操作这些数组来执行加密解密操作。 总结来说,通过JNI调用native方法实现加密解密,开发者可以充分...

    nodejs解密cryptojs

    这篇博文《nodejs解密cryptojs》将探讨如何在Node.js环境中使用CryptoJS进行加密和解密操作。 首先,理解加密的基本概念至关重要。加密是一种将可读数据(明文)转换为不可读数据(密文)的过程,以保护信息的安全...

    Nodejs中crypto模块的安全知识讲解

    对称加密使用相同的密钥进行加密和解密操作,比如AES、DES、3DES、Blowfish等算法,这要求密钥在安全地在通信双方间共享,其加密和解密的伪代码如下: ```javascript encryptedText = encrypt(plainText, key); // ...

    nodejs加密Crypto的实例代码-.pdf

    在这个实例中,我们主要关注的是加密和解密功能,特别是对称式和非对称式的加密方法。 对称式加密是一种常见的加密方式,它使用相同的密钥进行加密和解密。在示例中提到的DES(Data Encryption Standard)是一种...

    nodejs加密Crypto的实例代码-.docx

    1. **对称式加密**:使用相同的密钥进行加密和解密,如DES(Data Encryption Standard)。在提供的代码中,尽管没有直接展示对称加密的使用,但`crypto.createCipher()`和`crypto.createDecipher()`函数就是用于对称...

    nodejs加密Crypto的实例代码

    在这个类中,我们定义了`encrypt`和`decrypt`方法,它们会遍历配置的加密算法,尝试使用每个算法进行加密或解密。这使得我们可以灵活地选择不同的加密策略。 总的来说,Node.js的Crypto模块为开发者提供了丰富的...

    rsa-aes-utils:RSA、AES 加解密,支持 JavaScript 、Node.js、Java

    RSA、AES 加解密,浏览器端 JS 加密,服务端 nodejs、java 解密。 加解密介绍 加密算法分对称加密和非对称算法,其中对称加密算法的加密与解密密钥相同,非对称加密算法的加密密钥与解密密钥不同,此外,还有一类不...

    webcrypto:用于NodeJS的WebCrypto Polyfill

    模块基于NodeJS v10加密API。 它仅适用于Node v10及更高版本。 正在安装 npm install @peculiar/webcrypto 支持的算法 算法名称 generateKey 消化 出口进口 签名/验证 加密/解密 wrapKey / unwrapKey 派生 SHA-1 ...

    huffman_tree:使用 nodejs+express 实现 huffman encode decode 然后使用 DES encypt decypto

    3. DES加密:对哈夫曼编码后的数据进行DES加密,提供安全的传输。 4. DES解密:接收加密的哈夫曼编码数据,使用相同的密钥进行DES解密,然后进行哈夫曼解码,还原原始文本。 文件名“huffman_tree-master”可能是一...

    Node.js DES加密的简单实现

    最后,通过调用这两个方法,可以看到原始字符串`/upload/image/201602120012.jpg`经过加密和解密后,能够恢复到原始状态,验证了DES加密解密的正确性。 需要注意的是,DES由于其密钥长度较短,现在已经不再被视为...

    encrypt-decrypt:Java、Go、Python、NodeJS、PHP、JavaScript AESCBCPKCS7Padding 加解密

    常见的对称加密方式有 DES、3DES、AES、Blowfish、IDEA、RC5、RC6, 从安全性、资源消耗、运算速度、消耗时间综合来看 AES 都是值得选择的对称加密方式。 - 注意一下代码均为 DEMO 版本, 存在不严谨的地方,切勿直接...

    burpsuite JS加密插件jsEncrypter.0.3.2

    而Node.js服务器脚本则可能用于在后台处理加密解密过程,提供更高效的服务。 使用jsEncrypter时,首先需要将jsEncrypter.0.3.2.jar文件导入到BurpSuite中,然后配置好相应的设置,如选择服务器脚本类型(PhantomJS...

    JSpider:JSpider会每周更新至少一个网站的JS解密方式,欢迎Star,交流微信:13298307816

    对称性加密解密 DES DES是对称性加密里面常见的一种,全称为数据加密标准,即数据加密标准,是一种使用密钥加密的块算法。密钥长度是64位(bit),超过了数个密码被忽略。所谓对称性加密,加密和解密密钥相同。对称...

Global site tag (gtag.js) - Google Analytics