RSA 加密/解密—PKCS8 (Java与C#互通BouncyCastle)

2024-06-17 09:38

本文主要是介绍RSA 加密/解密—PKCS8 (Java与C#互通BouncyCastle),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前提:

需要调用JavaAPI进行签名/验签、加密/解密,需要使用BouncyCastle 类库进行Java与C#之间的数据互通。

 

加密理解点:

1:java 私钥采用的是PKCS8 ;C# 私钥采用的是PKCS1 格式

2:RSA加密 公钥加密,私钥解密或者私钥加密和公钥解密【这点和签名sign不同,sign需要私钥签名】

3:如果 java RSA加密 最后生成16进制 C#  也需要统一。这点一般需要确认最后生成的为base64还是16进制数据。

 

额外补充:

1:私钥,公钥注意去除空格,换行等(.Replace("\r", "").Replace("\n", "").Replace("\\s", ""))

2:加密 最后生成的一般为 byte数组 ,但是由于java中byte的范围在 [-128,127] 但是 C#中byte的范围在 [0,255]

并且使用byte不好进行对比传输,所以我们在进行签名或者加密时一般转化为字符串或者16进制。

 

BouncyCastle类库下载:

https://download.csdn.net/download/u011791378/11236710

 

******************以下时加密解密(C#与Java互通)BouncyCastle *************************

        /// <summary>/// 私钥加密2/// </summary>/// <param name="content">加密内容</param>/// <param name="PrivateKey">PKCS8私钥</param>/// <returns></returns>public string EncryptByPrivateKey2(string content, string PrivateKey){RsaKeyParameters PrivateKeyParam = (RsaKeyParameters)PrivateKeyFactory.CreateKey(Convert.FromBase64String(PrivateKey));var original = new BigInteger(Encoding.UTF8.GetBytes(content));//加密var encrypted = original.ModPow(PrivateKeyParam.Exponent, PrivateKeyParam.Modulus);//16进制return PayUtils.byteArray2HexString(encrypted.ToByteArray());//base64//return Convert.ToBase64String(encrypted.ToByteArray());}/// <summary>/// 公钥解密2/// </summary>/// <param name="content">解密内容</param>/// <param name="PublicKey">PKCS8公钥</param>/// <returns></returns>public string DecryptByPublicKey2(string content, string PublicKey){//base64//byte[] byteData = Convert.FromBase64String(content);//16进制var data = PayUtils.hexString2ByteArray(content);RsaKeyParameters PublicKeyParam = (RsaKeyParameters)PublicKeyFactory.CreateKey(Convert.FromBase64String(PublicKey));var encrypted = new BigInteger(data);//解密var decrypted = encrypted.ModPow(PublicKeyParam.Exponent, PublicKeyParam.Modulus);return Encoding.UTF8.GetString(decrypted.ToByteArray());}/// <summary>/// RSA公钥加密/// </summary>/// <param name="content">加密内容</param>/// <param name="publickey">公钥</param>/// <returns></returns>public string EncryptByPublicKey(string content, string publicKey){RsaKeyParameters publicKeyParam = (RsaKeyParameters)PublicKeyFactory.CreateKey(Convert.FromBase64String(publicKey));var original = new BigInteger(Encoding.UTF8.GetBytes(content));//加密var encrypted = original.ModPow(publicKeyParam.Exponent, publicKeyParam.Modulus);//16进制return PayUtils.byteArray2HexString(encrypted.ToByteArray());//base64//return Convert.ToBase64String(encrypted.ToByteArray());}/// <summary>/// RSA私钥解密/// </summary>/// <param name="content">解密内容</param>/// <param name="privateKey">私钥</param>/// <returns></returns>public string DecryptByPrivateKey(string content, string privateKey){//base64//byte[] byteData = Convert.FromBase64String(content);//16进制var data = PayUtils.hexString2ByteArray(content);RsaKeyParameters privateKeyParam = (RsaKeyParameters)PrivateKeyFactory.CreateKey(Convert.FromBase64String(privateKey));var encrypted = new BigInteger(data);//解密var decrypted = encrypted.ModPow(privateKeyParam.Exponent, privateKeyParam.Modulus);return Encoding.UTF8.GetString(decrypted.ToByteArray());}

*****************Bytes数组与16进制的转换*************************

        private static readonly string hexChars = "0123456789ABCDEF";/// <summary>/// Bytes数组转为16进制/// </summary>/// <param name="data"></param>/// <returns></returns>public static string byteArray2HexString(byte[] data){StringBuilder sb = new StringBuilder();for (int i = 0; i < data.Length; i++){byte lo = (byte)(0xF & data[i]);byte hi = (byte)((int)((uint)(0xF0 & data[i]) >> 4));sb.Append(hexChars.Substring(hi, 1)).Append(hexChars.Substring(lo, 1));}return sb.ToString();}/// <summary>/// 16进制转为Bytes数组/// </summary>/// <param name="hexStr"></param>/// <returns></returns>public static byte[] hexString2ByteArray(String hexStr){if (hexStr.Length % 2 != 0){return null;}byte[] data = new byte[hexStr.Length / 2];for (int i = 0; i < hexStr.Length / 2; i++){char hc = hexStr.Substring(2 * i, 1).ToCharArray()[0];//.charAt(2 * i);char lc = hexStr.Substring(2 * i + 1, 1).ToCharArray()[0];//.charAt(2 * i + 1);byte hb = hexChar2Byte(hc);byte lb = hexChar2Byte(lc);if ((hb < 0) || (lb < 0)){return null;}int n = hb << 4;data[i] = ((byte)(n + lb));}return data;}private static byte hexChar2Byte(char c){if ((c >= '0') && (c <= '9')){return (byte)(c - '0');}if ((c >= 'a') && (c <= 'f')){return (byte)(c - 'a' + 10);}if ((c >= 'A') && (c <= 'F')){return (byte)(c - 'A' + 10);}return 0;}

 

这篇关于RSA 加密/解密—PKCS8 (Java与C#互通BouncyCastle)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1069090

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr