微信JSAPI支付方式与错误(当前页面的URL未注册,支付验证签名失败)

微信JSAPI支付文档

前端调用JSAPI支付有两种方法

方法一:

  wx.chooseWXPay({
      // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
      timestamp: timestamp.toString(),
      // 支付签名随机串,不长于 32 位
      nonceStr: nonce_str,
      // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=\*\*\*)
      package: package,
      // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
      signType: "MD5",
      // 支付签名
      paySign: pay_sign,
      // 支付成功后的回调函数
      success: function (res) {
          // res.errMsg === 'chooseWXPay:ok'方式判断前端返回,微信团队郑重提示:
          // res.errMsg将在用户支付成功后返回ok,但并不保证它绝对可靠, 切记。
          if (res.errMsg === 'chooseWXPay:ok') {
          		// todo
          }
      },
      // 支付取消回调函数
      cancel: function (res) {
          that.$toast('用户取消支付~')
      },
      // 支付失败回调函数
      fail: function (res) {
          that.$toast('支付失败~')
      }
  })

方法二:

 WeixinJSBridge.invoke(
     "getBrandWCPayRequest",
     {
         appId: appId, //公众号名称,由商户传入
         timeStamp: timestamp.toString(), //时间戳,自1970年以来的秒数
         nonceStr: nonce_str, //随机串 后台生成
         package: package,
         signType: "MD5", //微信签名方式:
         paySign:sign //微信签名
     },
     res => {
         if (res.err_msg == "get_brand_wcpay_request:ok") {
             //微信团队郑重提示:res.err_msg 将在用户支付成功后返回 ok,但并不保证它绝对可靠。
             that.$toast.success("支付成功!");
         }
         if (res.err_msg == "get_brand_wcpay_request:fail") {
             that.$toast.fail("支付失败!");
         }
         if (res.err_msg == "get_brand_wcpay_request:cancel") {
             that.$toast.fail("支付已取消!");
         }
     }
 );

在开发过程中遇到当前页面的URL未注册的错误提示, 要注意, 当你的微信支付配置与文档无误以外, 看看转跳到此支付页的上一页A的路由是否与你设定的域名/授权目录/回调链接一致.
在这里插入图片描述
如:
微信设定的域名是:

https:ABCD.com/efg/

那么, A转跳到支付页面的路由应该是:

this.$router.push('https:ABCD.com/efg/?参数')

而不能是:

this.$router.push('https:ABCD.com/efg?参数')

注意, 当操作系统是ios的话, 转跳不能用router.push, 要使用 locaiton.href ,因为ios拿到的是第一个进入的链接

而当遇到支付验证签名失败这个提示时, 应提醒后端, 是否设定的参数与支付文档不一致, 且要留意, 支付签名是否需要二次签名. 当一切都与文档一致还是报此错误时, 要留意, 后端传给微信的参数要与前端一致, 如(timestamp, nonceStr等要一致)
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 中实现微信支付需要使用微信支付 SDK。您可以在微信支付官方网站上下载最新版本的 SDK,并在您的 Java 项目中使用它。 使用微信支付 SDK 的具体步骤如下: 1. 注册微信支付商户并获取商户 ID 和密钥。 2. 下载并导入微信支付 SDK。 3. 创建支付订单并获取支付二维码。 4. 使用扫码支付或者 JSAPI 支付接口调用微信支付。 5. 接收微信支付的异步通知并进行订单状态的更新。 有关微信支付的更多信息,您可以参考微信支付官方文档:https://pay.weixin.qq.com/wiki/doc/api/index.html 希望这些信息对您有帮助! ### 回答2: 要实现微信支付功能,可以使用Java编程语言结合微信支付开放平台提供的API来实现。 首先,需要在微信支付开放平台注册并创建一个应用,获取到应用的AppID、商户号、AppSecret等信息。 接下来,在Java项目中引入微信支付SDK,可以使用第三方库,如"wechatpay-api"来简化开发流程。然后,通过使用SDK提供的相关方法,可以实现以下功能: 1. 获取access_token:通过获取 access_token 接口,获取微信支付接口调用凭证,用于后续接口调用的身份验证。 2. 统一下单:使用统一下单接口,将用户提交的支付信息传给微信支付平台,生成预支付订单,并返回预付款二维码链接或者支付ID。 3. 生成支付链接或二维码:将预付款二维码链接或支付ID返回给前端,通过生成支付链接或者二维码的方式,提供给用户进行支付。 4. 微信支付回调:在用户支付成功后,微信支付平台会异步调用开发者设置的支付结果通知地址,向该地址发送支付结果信息。开发者需要在接收到回调时,验证回调的合法性,并及时处理支付结果。 5. 查询订单状态:通过订单查询接口,可以查询用户支付订单的当前状态,如支付成功、支付失败等。 6. 退款:使用退款接口,可以实现订单退款操作,退还用户支付的金额。 以上是使用Java实现微信支付的基本步骤。在具体实现过程中,还需注意接口调用的参数传递、异常处理、数据加密等问题。为确保支付安全,建议使用HTTPS协议进行数据传输,并加强对接口的签名验证。 ### 回答3: Java 实现微信支付可以通过微信支付开放平台提供的开发工具包来完成。首先,需要在微信支付开放平台注册一个开发者账号,并创建一个应用获取对应的应用ID和应用密钥。 接下来,可以使用Java语言进行开发。首先,需要引入微信支付的Java SDK,例如官方提供的weixin-java-pay SDK。通过在项目的pom.xml文件中添加相关依赖,即可将SDK集成到项目中。 然后,通过在代码中进行配置,将应用ID和应用密钥等信息设置到SDK中。可以使用SDK提供的配置类进行设置,例如WxPayConfig。 接下来,可以使用SDK提供的API进行微信支付的相关操作。例如,使用SDK提供的统一下单API可以生成一个支付链接,通过该链接用户可以进行支付操作。可以通过创建对应的请求对象,并调用SDK提供的发送请求的方法来实现。 支付结果通知可以使用SDK提供的回调接口来处理,当支付完成后,微信支付平台会向预先设置的回调URL发送通知。可以在代码中编写对应的处理逻辑,接收并解析微信支付平台发送的通知,校验数据的正确性,并进行相应的业务处理。 最后,可以使用SDK提供的查询订单API来查询订单的支付结果。可以根据订单号或其他查询条件,调用SDK提供的查询订单接口来获取订单的最新支付状态。 通过以上步骤,就可以使用Java实现微信支付功能。需要注意的是,开发过程中需要仔细阅读微信支付开放平台提供的文档和SDK的使用指南,并按照实际需求进行相关配置和操作。同时,为了确保支付过程的安全性,建议使用SSL证书进行加密传输。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值