文档章节

RSA加解密含java版互转

朝如青丝暮成雪
 朝如青丝暮成雪
发布于 2017/05/16 13:30
字数 375
阅读 21
收藏 0

下面是RSA的帮助类文件封装

http://git.oschina.net/awith/RSAHelper

最近公司项目做Socket对接接口,对方是java写的,密钥什么的都是java版本,在c#上需要进行转换,对接起来真是麻烦死人,记录下来,以后用到用来参考。

注意:不排除封装的RSAHelper有BUG。

我也先声明下RSA的使用方法:

公钥加密,私钥解密。

公钥验签,私钥签名。

问题1:在java中签名时候有个SHA1withRSA进行签名,这个签名就是用SHA1的Hash值就行了,在c#中通常是MD5进行签名,因此采用的是MD5的Hash值。

问题2:注意加解密、和签名时需要不需要进行Base64加解密,我封装的这个里面全部没有采用Base64加解密,但在c#大部分都会采用Base64加解密。

问题3:密钥的转换,java版本和c#版本的密钥是不一样的,需要注意。RSAHelper中有密钥转换的方法。

基于封装的RSAHelper写个实例:

//签名

//得到hash描述_msg是要参与签名的文本,
byte[] hashData = RSACryption.GetSHA1Hash(_msg);

//得到签名域值
byte[] signData = RSACryption.RSASignData(conf.MyPrivKey, hashData);

//验证签名
bool temp = RSACryption.RSAVerifySign(conf.MSPubKey, HashData, signDataByte);

 //得到密文

RSACryption.RSAEncrypt(conf.MSPubKey, _msg);

//解密
string msg = RSACryption.RSADecrypt(conf.MyPrivKey, msgByte);

 

c#和java公私钥互转就不写了,很简单。不过需要Nuget一个BouncyCastle

注意加密格式和形式一般不会出现什么问题.

 

 

 

 

© 著作权归作者所有

共有 人打赏支持
朝如青丝暮成雪
粉丝 5
博文 71
码字总数 30409
作品 0
浦东
程序员
私信 提问
Android外部文件加解密及应用实践

有这样的应用场景,当我们把一些重要文件放到asset文件夹中时,把.apk解压是可以直接拿到这个文件的,一些涉及到重要信息的文件我们并不想被反编译拿去,这个时候需要先对文件进行加密,然后...

C6C
05/08
0
0
浅析RSA公钥密码以及使用Java自带API实现RSA的密钥生成和加解密

RSA是目前最流行的非对称密码,目前广泛应用在数字签名,数字证书上。 那么什么是非对称密码呢?就是给明文加密的密钥和给密文解密的密钥是不一样的。其中,对外暴露的是公钥,自己保留的是私...

Lunqi
2015/07/15
0
1
关于一个RSA跨语言(java 和py)的加密解密操作

现在有一个需求,java平台提供接口,python平台调用接口,中间用到rsa进行接口的加密解密。java服务端的rsa加密操作已经完成,返回一个16进制的字符串给python平台,但是在python进行私钥解密...

我亦暖心丶
07/17
0
0
使用Hutool处理RSA等非对称加密

介绍 Hutool工具是一个国产开源Java工具集,旨在简化Java开发中繁琐的过程,Hutool-crypto模块便是针对JDK加密解密做了大大简化。 此文主要介绍利用Hutool-crypto简化非对称加密解密。 对于非...

路小磊
2017/08/24
0
22
Java结合keytool实现非对称加密和解密

原文出处:王洁 参考:Java结合keytool实现非对称签名与验证 那一篇讲签名,这一篇将加密解密。在Java安全体系中,签名属于JAAS模块,加解密属于JCE模块。 keytool的使用 keytool是JDK自带的...

王洁
08/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

腾讯与Github的魔幻会面背后的故事…

10月22日,腾讯开源管理办公室有幸邀请到Github新晋CEO Nat Friedman,前来鹅厂参观交流。目前腾讯已经有近70个项目在Github上开源,共获得17w stars,世界排名11位。Github是腾讯开源的主阵...

腾讯开源
20分钟前
0
0
单例模式

单例模式(Singleton pattern)属于创建型设计模式。 保证一个类仅有一个实例,并提供一个访问它的全局访问点。 通常我们可以让一个全局变量使得一个对象被访问,但它不能防止你实例化多个对...

NinjaFrog
25分钟前
0
0
TypeScript基础入门之装饰器(三)

转载 TypeScript基础入门之装饰器(三) 继续上篇文章[TypeScript基础入门之装饰器(二)] 访问器装饰器 Accessor Decorator在访问器声明之前声明。 访问器装饰器应用于访问器的属性描述符,可用...

durban
42分钟前
2
0
spring5调研学习(转载)

Spring框架的新功能 这一章主要提供Spring框架新的功能和变更。 升级到新版本的框架可以参考。Spring git。 内容列表 Spring 5.x框架新的功能 Spring 4.x框架新的功能 Spring 3.x框架新的功能...

小海bug
52分钟前
2
0
为何Spring框架能这么流行?

想要学习更多关于Spring框架在Java开发者中如此流行?看这篇文章可以学到更多! Spring框架特性 Spring是用于应用开发中的一款强大,轻量级框架。更广泛地说,你可以认为Spring框架是一个定义...

java知识分子
55分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部