最近走了很多坑,记录下:
#region 微信支付基本信息
public const string MchId = "1699999999";
public const string ApiV3Key = "asdfghjab639cb399cb371cbd893e15e";
//APIV2秘钥:ilrve9cab639cb39tcb371cbd893e18a 调用APIv2时,需用APIv2密钥签名,从而界定你的身份,需妥善保管防止泄露 (APIv2密钥与APIv3密钥互不影响)
//APIV3秘钥:asdfghjab639cb399cb371cbd893e15e 调用APIv3的下载平台证书接口、处理回调通知中报文时,要通过该密钥来解密信息
public const string AppId = "wx2fba12345806c75d";//开发者ID(AppID)
public const string P12Password = "1699999999";
public const string CertSerialNumber = "1810297430A25BC5254854585F2B748FE33789EB";//证书序列号
#endregion
#region 签名方法1:使用商户私钥签名:apiclient_cert.p12(调用下单接口 + JSAPI调起支付)
/// <summary>
/// 签名方法1:使用商户私钥签名:apiclient_cert.p12(调用下单接口 + JSAPI调起支付)
/// </summary>
/// <param name="message">需要签名的数据</param>
public static string GenerateSignatureA(string message)
{
string P12FilePath = HttpContext.Current.Server.MapPath("~/Content/apiclient_cert.p12");
X509Certificate2 cert = null;//new X509Certificate2(P12FilePath, P12Password, X509KeyStorageFlags.Exportable);
try
{
RSA rsa = null;
try// 加载p12证书
{
cert = new X509Certificate2(P12FilePath, P12Password, X509KeyStorageFlags.Exportable | X509KeyStorageFlags.MachineKeySet);
rsa = cert.GetRSAPrivateKey();
}
catch (Exception)
{
cert = new X509Certificate2(P12FilePath, P12Password, X509KeyStorageFlags.Exportable | X509KeyStorageFlags.DefaultKeySet);
rsa = cert.GetRSAPrivateKey();
}
if (rsa != null)
{
var signature = Convert.ToBase64String(rsa.SignData(Encoding.UTF8.GetBytes(message), HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1));
return signature;
}
else
{
//throw new InvalidOperationException("无法从p12证书中获取RSA私钥");
SLogText.WriteLog("签名A:RSA空null:", "RSA rsa = null");
return "";
}
}
catch (Exception ex)
{
// 这里可以记录日志或抛出更具体的异常
SLogText.WriteLog("签名A:报错:", ex.ToString() + ex.Message);
//throw new Exception("签名微信支付请求时出错", ex);
return "";
}
}
#endregion