- 浏览: 148084 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
qiuxue126com:
学习了 !
nodejs http 发送请求 -
ZZX19880809:
一笑而过就好了,反正我不赶铁路
铁道部那坑爹的系统。
Java和nodejs中des加解密数据互操作,直接上代码(仅供参考):
结果:
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
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
发表评论
-
Lua
2015-05-20 17:06 0local function bin2hex(s) ... -
nodejs http 发送请求
2014-04-26 09:30 59509GET请求 var http = require('htt ... -
Web_Quartz XML配置
2014-04-11 17:32 819classpath目录下:生成quartz.propertie ... -
Ant使用
2014-04-11 17:26 622<?xml version="1.0& ... -
nodejs process uncaughtException
2014-04-03 09:41 1091用过Node一段时间之后, ... -
ulimit 设置
2014-01-01 22:27 943最近NodeJs项目经常挂起,后台在日志发现,有一个Error ... -
Ubuntu设置JAVA环境变量
2013-12-25 14:11 1065ubuntu 设置java的环境变量 如果为所有用户的 sh ... -
node.js child_process simple operctor 2
2013-11-21 23:17 688[node.js] clied_process simple ... -
node.js child_process simple operctor
2013-11-21 23:16 623[node.js] child_process Simple ... -
node.js child_process operator( after ssh - cd & ls )
2013-11-21 23:03 1812[node.js] child_process ssh 远 ... -
Ubuntu 程序“javac”已包含在下列软件包中
2013-07-12 16:45 9746xusongqin@xusongqin-F83VF: ... -
(转)23种设计模式的记忆方法
2013-06-18 15:48 1128首先列出23种设计模式1 Singleton 单件2 Abs ... -
Node.js_Linux安装
2013-06-06 16:31 807介绍linux下的安装,Node在Linux环境下的安装和使用 ... -
Quartz时间配置
2013-05-07 11:39 628Seconds YES 0-59 , - * / ... -
JSP处理回车(\n)的处理
2013-04-02 11:51 4707在JSP里,JSTL(fn:replace)无法处理,回车(\ ... -
Js弹出层
2012-11-19 16:59 0弹出层:自创,虽说代码写得不好,可是自己精心布局. va ... -
resin,tomcat,weblogic各种调试配置
2012-10-16 17:53 1147很多时候,由于代码逻辑复杂,没有调试实在是很难受。肉眼的努力还 ... -
铁道部那坑爹的系统。
2012-09-27 16:40 1356铁道部那坑爹的系统,原来也是用开源框架的。无非也就是strus ... -
JDBC-SQL的输出
2012-09-12 18:06 1501前几天,有个朋友问我,怎么输出JDBC对DB的SQL?当时没明 ... -
Java-JDBC层 大量的Setter/Getter方法解决办法
2012-09-04 16:10 1716话不多说,直接上代码。两代关于JDBC的代码,结果集到类对象的 ...
相关推荐
实现3DES加密解密,当然也含基础的des加密解密
4.nodejs和java的AES加密结果保持一致.doc
opencv4nodejs github地址 https://github.com/justadudewhohacks/opencv4nodejs#how-to-install
一健国际化全流程解决方案,适用于Nodejs/VUE/REACT/uniapp等
C# JAVA nodejs通用的AES加密解密算法,考虑到实际使用过程中由于客户端和服务端使用的语言不一样而又需要对数据进行加密和解密的情况,特此总结了C# JAVA nodejs通用的AES加密解密算法,供需要者参考。
MagicCrypt 是一个 Java/PHP/NodeJS/Rust 库,用于加密/解密字符串、文件或数据,使用数据加密标准 (DES) 或高级加密标准 (AES) 算法。它支持 CBC 分组密码模式、PKCS5 填充和 64、128、192 或 256 位密钥长度。
实现了nodejs与java的相互通信功能,包括nodeClient访问javaServer,以及javaClient访问nodeServer,亲测有效,如果有问题请在下方留言,一定及时解答
nodejs系列学习:http请求html/css/js-----(二)
3.nodejs调用建行Java版加密Demo。参数为:flag,strSrcParas,PUBLICKEY,callback。 通过回调函数 得到加密串ccbParam。 nodejs调用java可以通过child_process模块中的spawn()函数实现。 var spawn = require('child_...
https://nodejs.org/en/download/ 公司内网打不开这个地址,上传资源 LTS版本
vue react javaweb nodejs 微信小程序 h5小游戏 一共6种项目合集,就是怕那天电脑挂掉,U盘坏了
一键升级git/nodejs/npm/Docker Engine/Docker-Compose/Python脚本。
nodejs和Java调用webservice接口总结 做了一天终于调通了 Java和node工程都是可以使用,随便总结一下,下次忘记咯
编译好的sqlcipher nw版本0.48.0,32位
nodejs64位安装包,只适用于Windows系统。 解压后直接进行安装
node.js与飞秋的通讯,RSA、blowfish加密解密消息。 下载代码 局域网内找台计算机运行飞秋 然后本机运行node testfeiq.js,远端计算机飞秋上发条消息给本机完成消息的加密解密测试。 详见博客 ...
nodejs 64位 官网http://nodejs.cn/ https://nodejs.org/en/
如何在nodejs项目中调用c++动态链接库,参考nodejs文档https://nodejs.org/dist/latest-v10.x/docs/api/addons.html#addons_c_addons 和 https://github.com/nodejs/node-gyp
安装npm/nodejs 二者之间的对应关系。 https://nodejs.org/zh-cn/download/releases/ 不建议自动安装(版本太老,且冲突) sudo apt -y install npm # 更新的并不是最新的。 sudo npm i npm@latest -g` sudo apt -...
money.js 是一个货币转换的微型 javascript 库,可在 nodeJS 和浏览器中使用