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

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件