码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C语言和Java中RSA算法一些注意事项


    最近因项目原因,需要Java端采用RSA加密后,吧公钥传给C端,在C端RSA解密。key 为2048位。

    Java端生成公私钥的一般方法如下:

    1. KeyPairGenerator gen = KeyPairGenerator.getInstance("RSA");
    2. gen.initialize(KEY_SIZE);
    3. gen.initialize(KEY_SIZE, new SecureRandom(RSAUtil.hexToByteArr(ORIGIN_HEX_STRING)));
    4. KeyPair pair = gen.generateKeyPair();
    5. // rsa生成一对公私钥
    6. PublicKey publicKey = pair.getPublic();
    7. PrivateKey privateKey = pair.getPrivate();
    8. String public64 = Base64.getEncoder().encodeToString(publicKey.getEncoded());
    9. String private64 = Base64.getEncoder().encodeToString(privateKey.getEncoded());
    10. System.out.println("generate public: " + public64);
    11. System.out.println("generate private64: " + private64);

     其生成的格式如下:

    其公钥长度超过256字节,而C语言端公钥就是256。那该传什么给C端呢?

    将key 进行encode编码,即调用publicKey.getEncoded() 后。

    其hex格式如下:

    30820122300d06092a864886f70d01010105000382010f003082010a02820101008760d419bdd1ec283d7aacda263830124576bddb219820cc3303cbb5cd00210abb55c271d687e77a44e6ab0d407af6785df389d823d61d8a1d54546c14537f3ef350389112ff1063b9b858544c6bc571a2774f72627f6ede196cecf22281c17a30a00892cc16af5c8762bf25d3b17b96b9a10f51b6257324a867e413be293f5dcd30d20cc9ab7ab3cd39840d0d721339623b6aa1481cc42e625a775f65b4b549df1a884a4619cb17e04f4ada2e8f03c362db43944b650b7877f1ae9fa11c7f9a92b1617de2df09c222f60654f15b93d0ee20b911d93e6fe7ec337767e76a8a767d73be83fbef0f8b7c0e7ecd6c8954bccd10f74a96730426ba42e67e82b9aac50203010001

    或者在网站 http://www.toolhelper.cn/EncodeDecode/Base64HexEncodeDecode 转换后

     其要传输的公钥为上图除红色框中的部分。

    参考 RSA公钥格式

    一般认为RSA2048加密时,要加密内容不能超过256字节,但是当用

    Cipher cipher = Cipher.getInstance("RSA/ECB/NoPadding");

     时,是能加密256字节内容的。参考:java与openssl的rsa算法互

    另外要注意:

    Java中还有一个专门的验签函数:Signature.getInstance(SIGN_METHOD);

    但是当与C端用RSA加解密验签时,不要用该函数,直接用Cipher 加密即可。

  • 相关阅读:
    设置快捷键
    Linux 实现原理 — NUMA 多核架构中的多线程调度开销与性能优化
    vue前端实现多个url下载并合并为zip文件
    【前端设计模式】之外观模式
    Codeforces Round #800 (Div. 2)
    【函数讲解】botorch中的函数 is_non_dominated():用于计算非支配(non-dominated)前沿
    shell之tar命令
    Java IO其它字符流简介说明
    如何判断域名的潜力和价值?
    视频中场的概念(1080I和1080P)和BT601/656/709/1120/2020/2077
  • 原文地址:https://blog.csdn.net/lanmengfenghe/article/details/127673484
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号