fxbszj 发表于 2015-12-10 23:20

求助:关于RSA加密,开源库

本人在做一个客户端,需要跟java服务端交互
首先会从java端请求RSA公钥,我需要将数据加密后再传给java端
因为第一次接触加密,就在网上找,最后看了openssl和crypto++。
openssl读取公钥文件总是结果为NULL,后来发现,openssl读取的公钥文件是有一定格式,有头有尾,中间还分行,我直接将java端传给我的存放到文件没法用。
关于crypto++,我看它生成密钥的时候有个seed,后面加密的时候都会用到这么seed,解密不用,我根本就没seed这玩意,java端也说也没有。我又不知道该怎么弄了
难道这么加密算法只能用它们自己生成的密钥??(我想应该不可能吧)

最后,也就是刚才的几个小时,我看了botan
这个倒是没有提到seed之类的,botan的公钥私钥、加密解密分别是4个类,看了几个小时不知道怎么弄?
可能整个过程我有些浮躁了,没能仔细看下去,但是确实有些着急,而且这几个开源库的注释都挺少的

有谁对这些比较了解的帮下我,谢谢,有demo就更好了。
谢谢各位

idi0t 发表于 2015-12-11 08:59

本帖最后由 idi0t 于 2015-12-11 09:01 编辑

openssl读取的公钥文件是有一定格式,有头有尾,中间还分行想想觉得应该不可能这样玩!
补充下,读文件有格式,肯定有从内存读入的方式,那样猜想就不会有什么格式要求吧。不然太...

folklore 发表于 2015-12-11 09:36

世上的RSA有百样红, 你想要的只有Java那一种。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。



所以, 忘了Cryp, 忘了openssl, 用Java写(如果有必要, 从C++调用Java)

lxyscls 发表于 2015-12-11 09:42

openssl读取的公钥文件是有一定格式,有头有尾,中间还分行,我直接将java端传给我的存放到文件没法用

    你把这个格式补全不就完了?加头加尾,多少char一行,全部补上,这些不都是固定的么

fxbszj 发表于 2015-12-11 10:54

回复 3# folklore
不会java,再说C++客户端还拖个java不太好吧

   

fxbszj 发表于 2015-12-11 10:56

idi0t 发表于 2015-12-11 08:59 static/image/common/back.gif
想想觉得应该不可能这样玩!
补充下,读文件有格式,肯定有从内存读入的方式,那样猜想就不会有什么格式要 ...
然后从哪着手呢

folklore 发表于 2015-12-11 12:26

回复 5# fxbszj


    上个帖子就已经给你答案了。 不会也得会啊。。。。。。。。。

1. Java用C++的RSA,
2. C++用Java的RSA。

总之你只能用统一的一种RSA。
RSA算法有2^2048种(我也试用C++实现过)。各种变种间不可能通信(实现细节上总有些微不同, 当然如果两种实现遵守相同规则就没问题)。

fxbszj 发表于 2015-12-11 13:16

回复 7# folklore
你的意思是,用一种RSA加密技术加密的以后,哪怕有公钥或者私钥,不同技术也不能解,是这么理解吗?


   

fxbszj 发表于 2015-12-11 13:42

folklore 发表于 2015-12-11 12:26 static/image/common/back.gif
回复 5# fxbszj



还有对称加密也是一样吗?只能使用同种加密算法?

langue 发表于 2015-12-14 00:30

你这样的需求,直接套用现成的 TLS 协议就可以满足,何必自己从各种原语开始写呢。
客户端向服务器请求公钥,用公钥加密再传输到服务器解密是不错,但你不知道那个公钥是真的还是伪造的,所以需要握手来验证身份。
密码学和传输层安全那些事,IETF 讨论十几年了,他们提供的安全建议远比你自己造轮子可靠。
页: [1] 2
查看完整版本: 求助:关于RSA加密,开源库