文档章节

Java DESede用C++ Openssl实现

suit
 suit
发布于 2012/10/26 21:31
字数 366
阅读 2112
收藏 4


最近在看一个项目的代码

开发语言:C++

开发环境:VS2005

但有一个很别扭的地方,就是这个项目与外界的加密算法采用DESede,但其实现是采用jni调用java vm里面的函数。

查了一下,可以用Openssl来实现,但要注意model(ECB)和padding(PKCS#5)



#资料

PKCS5, PKCS7和SSL3, 以及CMS(Cryptographic Message Syntax)

有如下相同的特点:
1)填充的字节都是一个相同的字节
2)该字节的值,就是要填充的字节的个数

如果要填充8个字节,那么填充的字节的值就是0×8;
要填充7个字节,那么填入的值就是0×7;

如果只填充1个字节,那么填入的值就是0×1;

这种填充方法也叫PKCS5, 恰好8个字节时还要补8个字节的0×08

正是这种即使恰好是8个字节也需要再补充字节的规定,可以让解密的数据很确定无误的移除多余的字节。


参考资料:

[1]Java DESede encrypt, OpenSSL equivalent

http://stackoverflow.com/questions/9038298/java-desede-encrypt-openssl-equivalent

[2] DES 算法的 C++ 与 JAVA 互相加解密

http://www.cnblogs.com/WonKerr/archive/2009/11/11/DES_C_JAVA.html

[3]Java中3DES加密解密与其他语言(如C/C++)通信

http://lijunjie337.iteye.com/blog/717911

[4]pkcs#5和pkcs#7填充的区别

http://hi.baidu.com/tweetyf/item/36d2f94a8639320ae8350480

[5]使用openssl库实现des,3des加密 

http://blog.chinaunix.net/uid-25943311-id-3020013.html

© 著作权归作者所有

suit
粉丝 4
博文 24
码字总数 13208
作品 0
广州
程序员
私信 提问
Android NDK开发之引入第三方库

在Android开发中我们经常要把一些比较看重安全或者计算效率的东西通过JNI调用C/C++代码来实现,如果需要实现的功能简单或者你的C/C++代码能力比较强,但是目前还是有很多功能强大的第三方库的...

大头呆
2018/12/04
0
0
关于java加密服务器端用C++解密的问题

小弟做android客户端,用RSA加密数据发送给服务器,服务器是C++实现,C++用openssl生成密钥对,C++的加解密填充方式都是RSA_PKCS1_PADDING,可是小弟用java的cipher= Cipher.getInstance("R...

暗夜七世界
2014/11/05
599
3
Java加密技术(二)——对称加密算法DES&AES

接下来我们介绍对称加密算法,最常用的莫过于DES数据加密算法。 DES DES-Data Encryption Standard,即数据加密算法。是IBM公司于1975年研究成功并公开发表的。DES算法的入口参数有三个:Key、...

mrliuze
2015/05/27
318
0
JNI调用c++实现AES加密解密

最近项目中用到数据加密解密的功能,由于Android、iOS以及服务器端都需要用到这个功能。而不同平台上加密出来的密文是不一样的,这样导致互相之间密文无法使用。于是决定使用C/C++完成加密解...

whoisliang
2018/01/25
281
0
com.sun.crypto.provider.SunJCE

Could not instantiate bean class [com.lz.monitor.alert.service.ServiceImp]: Constructor threw exception; nested exception is java.lang.NoClassDefFoundError: com.sun.crypto.provi......

随智阔
2014/03/06
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

从零基础到拿到网易Java实习offer,我做对了哪些事

作为一个非科班小白,我在读研期间基本是自学Java,从一开始几乎零基础,只有一点点数据结构和Java方面的基础,到最终获得网易游戏的Java实习offer,我大概用了半年左右的时间。本文将会讲到...

Java技术江湖
昨天
5
0
程序性能checklist

程序性能checklist

Moks角木
昨天
7
0
VUE 计算属性

本文转载于:专业的前端网站▶VUE 计算属性 1、示例代码 <!DOCTYPE html><html lang="zh"> <head> <meta charset="UTF-8" /> <title>vue示例</title> </hea......

前端老手
昨天
6
0
快速搭建LNMT平台和环境部署 Tomcat详解

Tomcat部署的基本概念 1. CATALINA_HOME与CATALINA_BASE分别指什么?     CATALINA_HOME指的是Tomcat的安装目录     bin:\\Tomcat一些脚本存放目录,比如启动脚本startup.bat/start...

网络小虾米
昨天
7
0
float浮动

float浮动 float浮动概念及原理: 文档流:文档流是文档中可显示对象在排列时所占用的位置。 加浮动的元素,会脱离文档流,会沿父容器靠左或靠右排列,如果之前已经有浮动的元素,会挨着浮动...

studywin
昨天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部