中行P1签名及验签
分享中国银行快捷.NET P1签名和验签方法代码中ReturnValue为自定义类型请无视
#region 验证签名
/// <summary>
/// 验证签名
/// </summary>
/// <param name="plainText">返回数据原文</param>
/// <param name="pubKeyPath">公钥证书地址</param>
/// <param name="signatureData">签名值</param>
/// <returns></returns>
public static bool VerifyBankGatewayShortPaySign(string plainText, string pubKeyPath, string signatureData)
{
bool bVerify;
try
{
//将base64签名数据转码为字节
byte[] signedBase64 = Convert.FromBase64String(signatureData);
byte[] orgin = Encoding.UTF8.GetBytes(plainText);
//加载公钥
X509Certificate2 x509_Cer1 = new X509Certificate2(pubKeyPath);
using (RSACryptoServiceProvider oRSA = new RSACryptoServiceProvider())
{
oRSA.FromXmlString(x509_Cer1.PublicKey.Key.ToXmlString(false));
bVerify = oRSA.VerifyData(orgin, "SHA1", signedBase64);
return bVerify;
}
}
catch (Exception ex)
{
return false;
}
}
#endregion
/// <summary>
/// 证书
/// </summary>
/// <param name="certifyFilePath">证书路径</param>
/// <param name="certifyPassWord">证书密码</param>
/// <returns></returns>
private static X509Certificate2 RetrieveX509Certificate(string certifyFilePath, string certifyPassWord)
{
if (string.IsNullOrEmpty(certifyPassWord))
return new X509Certificate2(certifyFilePath);
else
return new X509Certificate2(certifyFilePath, certifyPassWord);
}
#region 创建签名
/// <summary>
/// 根据原文创建P1签名
/// </summary>
/// <param name="plainText">请求数据原文</param>
/// <param name="prikeyPath">私钥证书地址</param>
/// <param name="pfxPwd">私钥密码</param>
/// <returns></returns>
public static string CreateBankGatewayShortPaySign(string plainText, string prikeyPath, string pfxPwd)
{
string sign;
try
{
byte[] plainByte = System.Text.Encoding.UTF8.GetBytes(plainText);
//加载私钥
X509Certificate2 myCert = RetrieveX509Certificate(prikeyPath, pfxPwd);
using (RSACryptoServiceProvider RSA = (RSACryptoServiceProvider)myCert.PrivateKey)
{
RSAPKCS1SignatureFormatter rsaDeformatter = new RSAPKCS1SignatureFormatter(RSA);
rsaDeformatter.SetHashAlgorithm("SHA1");
SHA1Managed sha = new SHA1Managed();
byte[] byteHash = sha.ComputeHash(plainByte);
//执行签名
byte[] encryptedSignatureData = rsaDeformatter.CreateSignature(byteHash);
sign = Convert.ToBase64String(encryptedSignatureData);
}
return sign;
}
catch (Exception ex)
{
return "";
}
}
#endregion
分享不易使用请关注点赞谢谢
中行P1签名及验签的更多相关文章
- .NET RSA解密、签名、验签
using System; using System.Collections.Generic; using System.Text; using System.IO; using System.Sec ...
- PHP SHA1withRSA加密生成签名及验签
最近公司对接XX第三方支付平台的代付业务,由于对方公司只有JAVA的demo,所以只能根据文档自己整合PHP的签名加密,网上找过几个方法,踩到各种各样的坑,还好最后算是搞定了,话不多说,代码分享出来. ...
- 几个例子理解对称加密与非对称加密、公钥与私钥、签名与验签、数字证书、HTTPS加密方式
# 原创,转载请留言联系 为什么会出现这么多加密啊,公钥私钥啊,签名啊这些东西呢?说到底还是保证双方通信的安全性与完整性.例如小明发一封表白邮件给小红,他总不希望给别人看见吧.而各种各样的技术就是为了 ...
- erlang的RSA签名与验签
1.RSA介绍 RSA是目前最有影响力的公钥加密算法,该算法基于一个十分简单的数论事实:将两个大素数相乘十分容易,但那时想要对 其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥,即公钥,而 ...
- Delphi微信支付【支持MD5和HMAC-SHA256签名与验签】
作者QQ:(648437169) 点击下载➨微信支付 微信支付api文档 [Delphi 微信支付]支持付款码支付.二维码支付.订单查询.申请退款.退款查询.撤销订单.关闭订单. ...
- Delphi支付宝支付【支持SHA1WithRSA(RSA)和SHA256WithRSA(RSA2)签名与验签】
作者QQ:(648437169) 点击下载➨Delphi支付宝支付 支付宝支付api文档 [Delphi支付宝支付]支持条码支付.扫码支付.交易查询.交易退款.退款查询.交易撤 ...
- RSA后台签名前台验签的应用(前台采用jsrsasign库)
写在前面 安全测试需要, 为防止后台响应数据返给前台过程中被篡改前台再拿被篡改后的数据进行接下来的操作影响正常业务, 决定采用RSA对响应数据进行签名和验签, 于是有了这篇<RSA后台签名前台验 ...
- Delphi RSA签名与验签【支持SHA1WithRSA(RSA1)、SHA256WithRSA(RSA2)和MD5WithRSA签名与验签】
作者QQ:(648437169) 点击下载➨ RSA签名与验签 [delphi RSA签名与验签]支持3种方式签名与验签(SHA1WithRSA(RSA1).SHA256WithRSA(RSA2)和M ...
- 密码基础知识(2)以RSA为例说明加密、解密、签名、验签
密码基础知识(1)https://www.cnblogs.com/xdyixia/p/11528572.html 一.RSA加密简介 RSA加密是一种非对称加密.是由一对密钥来进行加解密的过程,分别称 ...
随机推荐
- SQLMAP学习笔记1 access注入
SQLMAP学习笔记1 access注入 Sqlmap是开源的自动化SQL注入工具,由Python写成,具有如下特点: 完全支持MySQL.Oracle.PostgreSQL.Microsoft S ...
- NIO中的Buffer
public abstract class Buffer { // Invariants: mark <= position <= limit <= capacity private ...
- java.util.ConcurrentModificationException: null
是因为在map.foreach中又put新的值了 在map.foreach中可能是不可以增删改
- 20135234mqy 实验四
北京电子科技学院(BESTI) 实 验 报 告 课程:java程序设计 班级:1352 姓名:mqy 学号:20135234 成绩: 指导教师:娄嘉鹏 ...
- 小组冲刺第十一天站立会议(发布Alpha版+网站链接)
注: “助成”招聘网站链接:http://58.87.74.131:8080/zhucheng 欢迎大家进行评测. 一.任务看板: 二.燃尽图: 三.团队成员合照: 四.任务总结: 今天我们发布网站B ...
- Class 2 四则运算2的设计思路
设计思路 1.主函数中有一个大的for循环,用户可以一直随机得到相应题目.在嵌套一个循环,其可以直接确定题目数量:定义两个变量,分别作为四则运算的两个运算数,用随机数函数得到两个数值:再利用随机生成函 ...
- c++课的圆周面积
又回顾了一下一两个月没动过的类,似乎又有点手生了,不过还好还可以做. 在栋哥的推荐下下载了一个vs2015,表示从dev的白鼠形式的简单操作缓过来还有些不习惯呢,不过有些功能,例如诊断还是挺好用的 这 ...
- oh my god 四则运算
Week1地址:https://git.coding.net/leiqh549/four.git 需求分析: 1.一个生成n道四则运算的程序,要求数字在0-100间,运算符在3-5个之间且运算符至少包 ...
- grunt入门讲解6:grunt使用步骤和总结
Grunt是啥? 很火的前端自动化小工具,基于任务的命令行构建工具. Grunt能帮我们干啥? 假设有这样一个场景: 编码完成后,你需要做以下工作 HTML去掉注析.换行符 - HtmlMin CSS ...
- Mysql Group Replication 简介及单主模式组复制配置【转】
一 Mysql Group Replication简介 Mysql Group Replication(MGR)是一个全新的高可用和高扩张的MySQL集群服务. 高一致性,基于原生复制及p ...