免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6032 | 回复: 12
打印 上一主题 下一主题

[C++] 求助:关于RSA加密,开源库 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-12-10 23:20 |只看该作者 |倒序浏览
本人在做一个客户端,需要跟java服务端交互
首先会从java端请求RSA公钥,我需要将数据加密后再传给java端
因为第一次接触加密,就在网上找,最后看了openssl和crypto++。
openssl读取公钥文件总是结果为NULL,后来发现,openssl读取的公钥文件是有一定格式,有头有尾,中间还分行,我直接将java端传给我的存放到文件没法用。
关于crypto++,我看它生成密钥的时候有个seed,后面加密的时候都会用到这么seed,解密不用,我根本就没seed这玩意,java端也说也没有。我又不知道该怎么弄了
难道这么加密算法只能用它们自己生成的密钥??(我想应该不可能吧)

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

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

论坛徽章:
36
CU大牛徽章
日期:2013-09-18 15:24:20NBA常规赛纪念章
日期:2015-05-04 22:32:03牛市纪念徽章
日期:2015-07-24 12:48:5515-16赛季CBA联赛之辽宁
日期:2016-03-30 09:26:4715-16赛季CBA联赛之北控
日期:2016-03-30 11:26:2315-16赛季CBA联赛之广夏
日期:2016-05-20 15:46:5715-16赛季CBA联赛之吉林
日期:2016-05-24 11:38:0615-16赛季CBA联赛之青岛
日期:2016-05-30 13:41:3215-16赛季CBA联赛之同曦
日期:2016-06-23 16:41:052015年亚洲杯之巴林
日期:2015-02-03 15:05:04CU大牛徽章
日期:2013-09-18 15:24:52CU十二周年纪念徽章
日期:2013-10-24 15:46:53
2 [报告]
发表于 2015-12-11 08:59 |只看该作者
本帖最后由 idi0t 于 2015-12-11 09:01 编辑
  1. openssl读取的公钥文件是有一定格式,有头有尾,中间还分行
复制代码
想想觉得应该不可能这样玩!
补充下,读文件有格式,肯定有从内存读入的方式,那样猜想就不会有什么格式要求吧。不然太...

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
3 [报告]
发表于 2015-12-11 09:36 |只看该作者
世上的RSA有百样红, 你想要的只有Java那一种。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。



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

论坛徽章:
14
水瓶座
日期:2014-06-10 09:51:0215-16赛季CBA联赛之江苏
日期:2017-11-27 11:42:3515-16赛季CBA联赛之八一
日期:2017-04-12 14:26:2815-16赛季CBA联赛之吉林
日期:2016-08-20 10:43:1215-16赛季CBA联赛之广夏
日期:2016-06-23 09:53:58程序设计版块每日发帖之星
日期:2016-02-11 06:20:00程序设计版块每日发帖之星
日期:2016-02-09 06:20:0015-16赛季CBA联赛之上海
日期:2015-12-25 16:40:3515-16赛季CBA联赛之广夏
日期:2015-12-22 09:39:36程序设计版块每日发帖之星
日期:2015-08-24 06:20:002015亚冠之德黑兰石油
日期:2015-08-07 09:57:302015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2015-12-11 09:42 |只看该作者
openssl读取的公钥文件是有一定格式,有头有尾,中间还分行,我直接将java端传给我的存放到文件没法用


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

评分

参与人数 1信誉积分 +50 收起 理由
fxbszj + 50 很给力!

查看全部评分

论坛徽章:
0
5 [报告]
发表于 2015-12-11 10:54 |只看该作者
回复 3# folklore
不会java,再说C++客户端还拖个java不太好吧

   

论坛徽章:
0
6 [报告]
发表于 2015-12-11 10:56 |只看该作者
idi0t 发表于 2015-12-11 08:59
想想觉得应该不可能这样玩!
补充下,读文件有格式,肯定有从内存读入的方式,那样猜想就不会有什么格式要 ...

然后从哪着手呢

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
7 [报告]
发表于 2015-12-11 12:26 |只看该作者
回复 5# fxbszj


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

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

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

论坛徽章:
0
8 [报告]
发表于 2015-12-11 13:16 |只看该作者
回复 7# folklore
你的意思是,用一种RSA加密技术加密的以后,哪怕有公钥或者私钥,不同技术也不能解,是这么理解吗?


   

论坛徽章:
0
9 [报告]
发表于 2015-12-11 13:42 |只看该作者
folklore 发表于 2015-12-11 12:26
回复 5# fxbszj

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

论坛徽章:
0
10 [报告]
发表于 2015-12-14 00:30 |只看该作者
你这样的需求,直接套用现成的 TLS 协议就可以满足,何必自己从各种原语开始写呢。
客户端向服务器请求公钥,用公钥加密再传输到服务器解密是不错,但你不知道那个公钥是真的还是伪造的,所以需要握手来验证身份。
密码学和传输层安全那些事,IETF 讨论十几年了,他们提供的安全建议远比你自己造轮子可靠。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP