.pem證書轉xml格式字符串(.net)


有和銀行或者支付公司對接過API接口的人都知道,為了保證數據傳輸過程中的安全性,大部分公司會選擇證書來進行簽名和驗證。證書有不同格式的,如  .cer  .pfx  .pem  等。下面就來看看 .pem格式證書如何轉換成xml字符串。

 1.假設證書路徑存放在(F:/cer/public.pem   和  F:/cer/private.pem)

 2.添加BouncyCastle.Crypto.dll 引用

代碼如下:

using Org.BouncyCastle.Crypto.Parameters;
using Org.BouncyCastle.Security;
using System.IO;

 

string privatekeyConent=privateKeyContent("F:/cer/private.pem");//獲取pem私鑰正文內容

string publickeyConent = Utils.PublicKeyContent(“F:/cer/public.pem”);//獲取pem公鑰正文內容
RSACryptoServiceProvider RSAalg = new RSACryptoServiceProvider();

string privatekeyXml = ConvertToXmlPrivateKey(RSAalg, privatekeyConent);//把java的私鑰轉換成.net的xml格式

string publickeyXml = ConvertToXmlPublicJavaKey(RSAalg, publickeyConent);//把java的公鑰轉換成.net的xml格式
/// <summary>
///獲取pem私鑰正文內容
/// </summary>
/// <param name="filePath">私鑰證書路徑</param>
/// <returns></returns>
public static string privateKeyContent(string filePath)
{

  string content= File.ReadAllText(filePath, Encoding.ASCII);//獲取pem證書完整內容
  if (string.IsNullOrEmpty(content))
  {
    throw new ArgumentNullException("pemFileConent", "This arg cann't be empty.");
  }
  string privatekeyConent= content.Replace("-----BEGIN PRIVATE KEY-----", "").Replace("-----END PRIVATE KEY-----", "").Replace("\n", "").Replace("\r", "");//去掉證書的頭部和尾部
  return privatekeyConent;
}

/// <summary>
///獲取pem公鑰正文內容
/// </summary>
/// <param name="filePath">私鑰證書路徑</param>
/// <returns></returns>
public static string publicKeyContent(string filePath)
{

  string content= File.ReadAllText(filePath, Encoding.ASCII);//獲取pem證書完整內容

  if (string.IsNullOrEmpty(content))
  {
    throw new ArgumentNullException("pemFileConent", "This arg cann't be empty.");
  }
  string publickeyConent = content.Replace("-----BEGIN PUBLIC KEY-----", "").Replace("-----END PUBLIC KEY-----", "").Replace("\n", "").Replace("\r", "");//去掉證書的頭部和尾部
  return publickeyConent ;

}

/// <summary>
/// 把java的私鑰轉換成.net的xml格式
/// </summary>
/// <param name="rsa"></param>
/// <param name="privateJavaKey"></param>
/// <returns></returns>
public static string ConvertToXmlPrivateKey(this RSA rsa, string privateJavaKey)
{
  RsaPrivateCrtKeyParameters privateKeyParam = (RsaPrivateCrtKeyParameters)PrivateKeyFactory.CreateKey(Convert.FromBase64String(privateJavaKey));
  string xmlPrivateKey = string.Format("<RSAKeyValue><Modulus>{0}</Modulus><Exponent>{1}</Exponent><P>{2}</P><Q>{3}</Q><DP>{4}</DP><DQ>{5}</DQ><InverseQ>{6}</InverseQ><D>{7}</D></RSAKeyValue>",
  Convert.ToBase64String(privateKeyParam.Modulus.ToByteArrayUnsigned()),
  Convert.ToBase64String(privateKeyParam.PublicExponent.ToByteArrayUnsigned()),
  Convert.ToBase64String(privateKeyParam.P.ToByteArrayUnsigned()),
  Convert.ToBase64String(privateKeyParam.Q.ToByteArrayUnsigned()),
  Convert.ToBase64String(privateKeyParam.DP.ToByteArrayUnsigned()),
  Convert.ToBase64String(privateKeyParam.DQ.ToByteArrayUnsigned()),
  Convert.ToBase64String(privateKeyParam.QInv.ToByteArrayUnsigned()),
  Convert.ToBase64String(privateKeyParam.Exponent.ToByteArrayUnsigned()));
  return xmlPrivateKey;
}

/// <summary>
/// 把java的公鑰轉換成.net的xml格式
/// </summary>
/// <param name="privateKey">java提供的第三方公鑰</param>
/// <returns></returns>
public static string ConvertToXmlPublicJavaKey(this RSA rsa, string publicJavaKey)
{
  RsaKeyParameters publicKeyParam = (RsaKeyParameters)PublicKeyFactory.CreateKey(Convert.FromBase64String(publicJavaKey));
  string xmlpublicKey = string.Format("<RSAKeyValue><Modulus>{0}</Modulus><Exponent>{1}</Exponent></RSAKeyValue>",
  Convert.ToBase64String(publicKeyParam.Modulus.ToByteArrayUnsigned()),
  Convert.ToBase64String(publicKeyParam.Exponent.ToByteArrayUnsigned()));
  return xmlpublicKey;
}
View Code

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM