0

0

实现C#与PHP之间RSA加密数据互通:XML密钥转换与解密流程

心靈之曲

心靈之曲

发布时间:2025-12-03 13:20:16

|

468人浏览过

|

来源于php中文网

原创

实现C#与PHP之间RSA加密数据互通:XML密钥转换与解密流程

本教程详细指导如何在c#应用程序中进行rsa数据加密,并实现在php环境中安全解密。核心内容涵盖c# `rsacryptoserviceprovider`的使用、将c#导出的xml格式rsa私钥转换为php兼容的pem格式,以及在php中使用`openssl_private_decrypt`函数对base64编码的密文进行解密,确保跨平台数据加密与解密的互操作性。

RSA(Rivest-Shamir-Adleman)是一种广泛使用的非对称加密算法,常用于数据传输的安全保障。在跨平台应用中,如C#后端加密数据,PHP前端或另一个服务进行解密,密钥格式和数据处理方式的差异往往是实现互通的关键挑战。本教程将详细阐述如何解决C# XML格式密钥与PHP PEM格式密钥之间的兼容性问题,并提供完整的加密解密流程。

C# RSA 加密实现

在C#中,我们通常使用System.Security.Cryptography命名空间下的RSACryptoServiceProvider类来执行RSA加密操作。以下是一个用于生成RSA密钥对并进行数据加密的示例类:

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;
using System.Xml.Serialization;

namespace TEST
{
    public class RSAEncrypter
    {
        // 静态RSACryptoServiceProvider实例,用于密钥操作和加解密
        private static RSACryptoServiceProvider RSA;
        private RSAParameters _privateKey; // 存储私钥参数
        private RSAParameters _publicKey;  // 存储公钥参数

        /// 
        /// 构造函数:初始化RSA密钥对
        /// 
        public RSAEncrypter()
        {
            // 创建一个2048位的RSA密钥对
            RSA = new RSACryptoServiceProvider(2048);
            // 导出私钥参数(包含私有和公共部分)
            _privateKey = RSA.ExportParameters(true);
            // 导出公钥参数(仅包含公共部分)
            _publicKey = RSA.ExportParameters(false);
        }

        /// 
        /// 使用指定的公钥加密纯文本数据
        /// 
        /// 待加密的纯文本
        /// XML格式的公钥字符串
        /// Base64编码的密文
        public string Encrypt(string plainText, string publicKey)
        {
            // 将传入的XML格式公钥字符串导入到RSA实例中
            RSA.FromXmlString(publicKey);
            // 再次导出公钥参数(这一步确保RSA实例内部使用的是传入的公钥)
            _publicKey = RSA.ExportParameters(false);
            // 重新导入公钥参数(确保加密操作使用正确的公钥)
            RSA.ImportParameters(_publicKey);

            // 将纯文本转换为Unicode字节数组
            var data = Encoding.Unicode.GetBytes(plainText);
            // 使用RSA公钥加密数据,第二个参数false表示使用PKCS#1 v1.5填充
            var cypher = RSA.Encrypt(data, false);
            // 将加密后的字节数组转换为Base64字符串返回
            return Convert.ToBase64String(cypher);
        }

        /// 
        /// 获取当前实例生成的XML格式私钥字符串
        /// 
        /// XML格式的私钥字符串
        public string PrivateKeyString()
        {
            var sw = new StringWriter();
            var xs = new XmlSerializer(typeof(RSAParameters));
            // 序列化私钥参数为XML字符串
            xs.Serialize(sw, _privateKey);
            return sw.ToString();
        }
    }
}

代码说明:

  • RSACryptoServiceProvider(2048):初始化一个2048位的RSA密钥对。密钥长度越长,安全性越高,但加解密速度会相应变慢。
  • ExportParameters(true):导出包含私有和公共部分的密钥参数。
  • ExportParameters(false):仅导出公共密钥参数。
  • FromXmlString(publicKey):将XML格式的公钥字符串导入到RSACryptoServiceProvider实例中,使其能够使用该公钥进行加密。
  • Encoding.Unicode.GetBytes(plainText):将明文转换为UTF-16LE编码的字节数组。这是C#中string的默认编码,也是RSA.Encrypt接受的输入格式之一。
  • RSA.Encrypt(data, false):执行加密操作。第二个参数false表示使用PKCS#1 v1.5填充(PKCS1_PADDING)。
  • Convert.ToBase64String(cypher):将加密后的二进制数据转换为Base64字符串,方便传输和存储。
  • PrivateKeyString():此方法将生成的私钥以XML格式的字符串形式导出,其结构包含Modulus、Exponent、P、Q、DP、DQ、InverseQ和D等RSA参数。

C#导出的私钥XML格式示例如下:

立即学习PHP免费学习笔记(深入)”;



  AQAB
  38Z4+7H1ADzMPO8z5+QdxXS21YBEaq9Xacf7dHFXUpK72SUAIYnfijc5RDSgGFismTNlrrOa7m/6+iIWS/yB7+esvIjgfSFm+QU2aeC16NisMuw+KvPeEr8CVMjh8F5YW1ST4qKXHXG6qIe/FM2LPVGV92O9WO1ATIDcATO8UU2rJgrxKMdmE9fawqmy/j7fwI1+FL6LCNgdvgZ3OOLLwHVcyOyj7ibiIUQAcw10qW0I4MBnQL5V8udKrhKXKoVE6rsfLZoBC9rBD62ckB7CJfMsGcAVffBvnd7SRJiTFEEPVZFqzyGk0BOeqbJkHbzKNytNkUjnFQlDX9tSLCtufQ==
  

密钥格式转换:从C# XML到PHP PEM

PHP的openssl扩展主要支持PEM(Privacy-Enhanced Mail)格式的密钥。因此,C#导出的XML格式私钥无法直接用于PHP的openssl_private_decrypt函数。我们需要一个中间步骤来将XML格式的私钥转换为PEM格式。

Magic Write
Magic Write

Canva旗下AI文案生成器

下载

通常,这个转换过程需要解析XML中的各个RSA参数(如Modulus, Exponent, P, Q, D等),然后使用ASN.1编码规则重新构建PEM格式的私钥。由于这是一个相对复杂的二进制编码过程,可以借助现有的工具或代码库。一个非常有用的C#代码片段可以在GitHub Gist上找到,它提供了将RSAParameters导出为PEM格式的功能:

您需要将此Gist中的转换逻辑集成到您的C#应用程序中,以便将PrivateKeyString()方法生成的XML私钥进一步转换为PEM格式。转换后的PEM格式私钥通常以-----BEGIN RSA PRIVATE KEY-----开头,以-----END RSA PRIVATE KEY-----结尾,中间是Base64编码的密钥数据。

PHP RSA 解密实现

在PHP中,使用openssl_private_decrypt函数结合PEM格式的私钥来解密数据。解密前,由于C#加密后将密文Base64编码,PHP需要先对其进行base64_decode。

代码说明:

  • `base64_decode($encrypted

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2643

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1635

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1513

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1418

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1448

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

68

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.8万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号