支付宝异步回调验证签名的那些走过的坑

liuqiwang 2018-06-22 原文

支付宝异步回调验证签名的那些走过的坑

今天做支付宝接口回调这块,不得不说,弄的我焦头烂额,翻了很多陈年旧帖,试了无数种解决坑的方案,在我成功解决的一瞬间,觉得非常有必要记录一下这些坑。

签名验证错误的检查顺序(这里是基于使用官方给的demo,自己封装的请绕道):

1:检查一下你使用的验证签名的方法是否正确?

bool signVerified = AlipaySignature.RSACheckV1(dic, alipay_public_key, config.charset);

2:检查一下你传入的参数是否正确?

参数1:dic,把回调的参数保存到key,value集合中

Dictionary<string, string> dic = new Dictionary<string, string>();
var form = HttpContext.Current.Request.Form;
string str = "异步通知:\r\n";
foreach (var key in form)
{
   dic[key.ToString()] = HttpContext.Current.Request.Form[key.ToString()];
   var value = HttpContext.Current.Request.Form[key.ToString()];
   //记录日志使用
   str += $"{key.ToString()}:{value}\r\n";
}

参数2:alipay_public_key

这个参数是 支付宝公钥!!   很多小伙伴都写成了应用公钥,瞎几把写。

参数3:编码格式,UTF-8,这个一般没人会错。

3:检查一下你的环境,沙盒环境还是线上环境,沙盒环境会出错,具体为什么我不知道,百度来的。要在支付宝中给你的回调域名授权,不授权人家懒得回调给你。

 

4:检查一下你的加密解密类型,我从官网下载下来的demo里面的解密类型默认是RSA,但是官方文档已经明确说明现在都要用RSA2了,所以记得检查demo的源码

public static bool RSACheckV1(IDictionary<string, string> parameters, string publicKeyPem, string charset)
{
   string sign = parameters["sign"];
   string sign_type = parameters["sign_type"];
   parameters.Remove("sign");
   parameters.Remove("sign_type");
   string signContent = GetSignContent(parameters);
   return RSACheckContent(signContent, sign, publicKeyPem, charset, sign_type);
}

sign_type,这个就是解码类型,demo写的好像“RSA”,我这里改成动态获取了,我们在前期配置的地方也会配置加密类型,从哪获取都可以,别弄错了就行。

5:这里不检查了,回忆一下你的支付宝公钥,是直接存在文本中的,还是写在代码里的(区别:公钥.txt,string 公钥 = “巴拉巴拉巴拉一大堆”),一个是文件,一个是直接代码(我就是代码,所以我一直到最后才解决)(下面的解决方案只针对代码保存支付宝公钥的骚年)

string alipay_public_key = "-----BEGIN PUBLIC KEY-----\r\n" + config.alipay_public_key + "-----END PUBLIC KEY-----\r\n\r\n";
bool signVerified = AlipaySignature.RSACheckV1(dic, alipay_public_key, config.charset);

如果是直接写在代码中的,要给支付宝公钥的头跟尾加上标识,具体标识看我贴出来的代码,如果是文件,请自动忽略

还没结束,官方给的demo也是默认找的文件,可是我用的代码存的,哪有文件,所以找不到文件是会报错的,报错直接返回false了,在修改一下源码(自己到AlipaySignature这个类里面去找)

public static bool RSACheckContent(string signContent, string sign, string publicKeyPem, string charset, string signType)
{

    try
    {
        if (string.IsNullOrEmpty(charset))
        {
            charset = DEFAULT_CHARSET;
        }

        if ("RSA2".Equals(signType))
        {
            //这里就是要改的地方
            //从参数获取
            string sPublicKeyPEM = publicKeyPem;
            //从文件获取
            //string sPublicKeyPEM = File.ReadAllText(publicKeyPem);
            RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
            rsa.PersistKeyInCsp = false;
            RSACryptoServiceProviderExtension.LoadPublicKeyPEM(rsa, sPublicKeyPEM);

            bool bVerifyResultOriginal = rsa.VerifyData(Encoding.GetEncoding(charset).GetBytes(signContent), "SHA256", Convert.FromBase64String(sign));
            return bVerifyResultOriginal;

        }
        else
        {
            //这里就是要改的地方
            //从参数获取
            string sPublicKeyPEM = publicKeyPem;
            //从文件获取
            //string sPublicKeyPEM = File.ReadAllText(publicKeyPem);
            RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
            rsa.PersistKeyInCsp = false;
            RSACryptoServiceProviderExtension.LoadPublicKeyPEM(rsa, sPublicKeyPEM);

            SHA1CryptoServiceProvider sha1 = new SHA1CryptoServiceProvider();
            bool bVerifyResultOriginal = rsa.VerifyData(Encoding.GetEncoding(charset).GetBytes(signContent), sha1, Convert.FromBase64String(sign));
            return bVerifyResultOriginal;
        }

    }
    catch (Exception e)
    {
        NLogGetter.NLog.ErrorLog(e);
        return false;
    }

}

好了,差不多就总结了这么多,基本上可以让你签名验证成功了。

版权声明:本文为liuqiwang原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/liuqiwang/p/9213502.html

支付宝异步回调验证签名的那些走过的坑的更多相关文章

  1. 支付宝支付(沙箱环境&真实支付)使用详解—python

    .MathJax, .MathJax_Message, .MathJax_Preview { display: none } 支付宝支付(沙箱环境&真实支付)使用详解---python_骑台风走的博客-CSDN博客_支付宝支付沙箱环境原文...

  2. 支付宝、微信发声禁止虚拟币交易,网友:我的“花钱自由”呢?

    https://www.infoq.cn/article/hlNbaptw7PdXqFq9bGKj 这可能又间 […]...

  3. 个人支付接入-个人app支付微信支付、支付宝支付接入(1分钟完成接入)

    作为一个应用爱好个人开发者,最开始在个人的应用中接入广告,但是用户反映体验太差,后来转换为应用支付。用户还比较 […]...

  4. 新增秒杀功能、优惠券、支付宝、Docker,newbee-mall升级版开源啦!

    新蜂商城升级版本newbee-mall-plus开源啦! 最近是非常非常非常忙,一方面是公司的事情比较多,另外 […]...

  5. 支付宝退款 (新版)

    实现支付宝退款  http://www.upwqy.com/details/85.html 想要实现退款,前提 […]...

  6. 支付宝 手机页面支付 集成 出现 “系统繁忙,请稍后再试”

    参照支付宝官网上的demo,链接生成,顺利跳转,没有报错,但是却出现问题如图问题:全部测试的手机都出现这种情况 […]...

  7. 支付宝 APP支付(证书)方式遇到的问题和解决办法 – 做梦都在写代码

    支付宝 APP支付(证书)方式遇到的问题和解决办法 最近在做支付宝的支付功能,遇到了一些问题记录一下,方便查阅 […]...

  8. 移动支付–银联,支付宝,微信(android) – jzssuanfa

    移动支付–银联,支付宝,微信(android)      在这个移动互联网快速发展的时代,手机已经 […]...

随机推荐

  1. 修复损坏的 shapefile

    一、SHP文件 Shapefile文件(简称SHP)作为ESRI一种经典的数据格式,被很多其他软件所支持,如C […]...

  2. [Windows] 系统清理与优化神器Advanced SystemCare 13 PRO非破解附正版激活码

    Advanced SystemCare是一款功能强大的系统清理优化软件,该软件提供的主要功能有:启动项优化、注 […]...

  3. 苹果系统浏览器清空缓存路径

    苹果系统浏览器清空缓存路径 /Users/hangliao/Library/Caches/com.apple. […]...

  4. 一些SpringBoot的初步理解

    SpringBoot SpringBoot作为近几年很火的微服务框架,只需要简单的几个依赖,少量的配置,就可以 […]...

  5. 软工最后一次作业

    总结 1.刚上这门课时对这么课的内容不是很了解,也不知道要学什么,对于软件工程这四个字也很陌生,什么是软件工程 […]...

  6. office 2010每次打开word都要重新配置的解决方法

        office 2010每次打开word都要重新配置的解决方法: 在“运行”中输入 reg add HK […]...

  7. Linux CentOS7.x 升级内核的方法

    一、概述      在数据中心基础环境中,Linux系统使用很普遍,但是有时候会遇到应用程序需要运行在高版本的 […]...

  8. 图像的卷积(滤波)运算(一)——图像梯度

    目录 1. 卷积/滤波原理 2. 具体实例 3. 图像梯度图 4. 参考资料 @ 1. 卷积/滤波原理 首先要 […]...

展开目录

目录导航