收藏
回答

微信支付v3 jsapi调起支付时,支付验证签名失败?

搞了好久了,这个签名到底怎么玩?

https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter3_1_4.shtml

回答关注问题邀请回答
收藏

5 个回答

  • lee
    lee
    01-11
    注意参数拼接 prepay_id=
    
    01-11
    有用
    回复
  • 孤独狂饮
    孤独狂饮
    2022-03-24

    给大家同步一下我这边的方案,2022年03月24日:

    最终解决方案是:让后台返回所有需要的字段,客户端拿着数据,直接请求服务器,即可吊起微信支付。

    示例:

    PayReq request = new PayReq();
    // 应用ID (可本地写死,也可服务器返回)
    request.appId = PayConstants.WX_APP_ID;
    // 商户号 (可本地写死,也可服务器返回)
    request.partnerId = PayConstants.WX_APP_MICID;
    // 预支付交易会话ID, 微信返回的支付交易会话ID
    request.prepayId = mPayOrderBean.getPrepay_id();
    // 扩展字段, 固定值:Sign=WXPay, (可本地写死,也可服务器返回)
    request.packageValue = "Sign=WXPay";
    // 随机字符串, 随机生成 随机字符串,不长于32位。推荐随机数生成算法,服务器生成 (最好是 32 位,如果是 低于 12 位,可能有问题)
    request.nonceStr = mPayOrderBean.getNonceStr();
    // 时间戳,一定是服务器的时间戳 (最好是服务器的时间戳)
    request.timeStamp = mPayOrderBean.getTimestamp();
    // 签名 (这个签名是后端根据证书签名的,一定不要自己写哦,要不然调试好久都没结果)
    request.sign = mPayOrderBean.getSign();
    // 这个字段可有可无。建议还是带上。
    request.extData = "app data";
    mIWXAPI.sendReq(request);
    



    简单描述:

    1. 服务器使用下单接口后,会返回 (以下是测试数据):
    { 
      "return_code": "SUCCESS", 
      "return_msg": "OK",
      "appid": "APPID", 
      "mch_id": "商户号", 
      "nonce_str": "随机字符串", 
      "sign": "081675D3A89B1A735613CF2D777E6F06", 
      "prepay_id": "wx201706052018103dd047b0880123350695", 
      "result_code": "FAIL", 
      "err_code": "ORDERPAID", 
      "err_code_des": "该订单已支付" 
    }
    



    2 其中比较关键是: sign。 这个返回客户端也不行,需要服务器做二次加密。

    具体是:

    "appid=" + appid + "&noncestr=" + nonce_str + "&package=Sign=WXPay" + "&partnerid=" + mch_id + "&prepayid=" + prepayid + "&timestamp=" + timeStamp + "&key=" + key;
    


    一定要注意:这里的key为商户的key,而不是AppSecret;timestamp为当前的时间戳

    3 最后返回的字段:

    { 
      "appid": "第1步的APPID", 
      "mch_id": "第1步的mch_id", 
      "prepay_id": "第1步的prepay_id", 
      "nonce_str": "第1步的nonce_str", 
      "sign": "第3步的签名,不是第1步的签名",
      "timestamp":"第3步的时间戳"
    }
    


    4 注意查看我上面的注释,错一个,就会提示签名失败。


    参见:

    1. https://juejin.cn/post/6844903832875433991 (比较细致)
    2. https://blog.csdn.net/github_39118247/article/details/100198628 (比较老,或者适合客户端直接操作具体数据)



    2022-03-24
    有用
    回复
  • 胡韵
    胡韵
    2021-10-18
    微信官方V3提供的RsaCryptoUtil 和文档要求的SHA256withRSA 不是同类的
    Signature sign = Signature.getInstance("SHA256withRSA");
    sign.initSign(privateKey);
    sign.update(signatureStr.getBytes(StandardCharsets.UTF_8));
    即可
    


    2021-10-18
    有用
    回复
  • 北望沣渭
    北望沣渭
    2021-03-30
    const {Rsa, Formatter} = require('wechatpay-axios-plugin')
    const privateKey = require('fs').readFileSync('/your/merchant/priviate_key.pem')
    
    const params = {
      appId: 'wx8888888888888888',
      timeStamp: `${Formatter.timestamp()}`,
      nonceStr: Formatter.nonce(),
      package: 'prepay_id=wx201410272009395522657a690389285100',
      signType: 'RSA',
    }
    params.paySign = Rsa.sign(Formatter.joinedByLineFeed(
      params.appId, params.timeStamp, params.nonceStr, params.package
    ), privateKey)
    
    
    console.info(params)
    
    2021-03-30
    有用
    回复 4
    • DH
      DH
      2021-09-28
      为什么要formatter一下
      2021-09-28
      回复
    • 北望沣渭
      北望沣渭
      发表于移动端
      2021-09-28回复DH
      因为官方开发文档上注明了,需要按格式要求编排后再加签
      2021-09-28
      回复
    • 雅彤
      雅彤
      2021-12-31
      换成php的用法 怎么实现呢
      2021-12-31
      回复
    • 北望沣渭
      北望沣渭
      2021-12-31回复雅彤
      2021-12-31
      回复
  • Memory (私信不回复)
    Memory (私信不回复)
    2021-03-30

    你可以看这里https://pay.weixin.qq.com/wiki/doc/apiv3/wechatpay/wechatpay-1.shtml

    2021-03-30
    有用
    回复 2
    • O_o
      O_o
      发表于移动端
      2021-03-30
      ok,晚上看下
      2021-03-30
      回复
    • kris webber
      kris webber
      2021-08-16
      一毛一样的问题,哥们 你搞定了么?
      2021-08-16
      回复
登录 后发表内容
问题标签