微信JSAPI公共号支付及常见问题处理

微信官方文档地址:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_3

前期准备:
  1. 设置支付目录
  2. 设置授权域名
开发步骤:

调用微信统一下单接口https://api.mch.weixin.qq.com/pay/unifiedorder

获取微信支付四大参数
公众APPID,APPSECEPT ,微信商户平台商户ID, API密钥

统一下单参数说明:
参数名 参数说明
appid 公共号appId
mch_id 微信支付商户号id
device_info 自定义参数,可以为终端设备号(门店号或收银设备ID),PC网页或公众号内支付可以传"WEB"
nonce_str 随机字符串,长度要求在32位以内。
sign 通过签名算法计算得出的签名值
sign_type 签名类型,默认为MD5,支持HMAC-SHA256和MD5
body 商品简单描述
out_trade_no 商户系统内部订单号
total_fee 订单总金额,单位为分
spbill_create_ip 支持IPV4和IPV6两种格式的IP地址。用户的客户端IP
notify_url 异步接收微信支付结果通知的回调地址,通知url必须为外网可访问的url,不能携带参数。
trade_type JSAPI -JSAPI支付、NATIVE -Native支付、APP -APP支付
product_id trade_type=NATIVE时,此参数必传。此参数为二维码中包含的商品ID,商户自行定义。
openid trade_type=JSAPI时(即JSAPI支付),此参数必传,此参数为微信用户在商户对应appid下的唯一标识

参数举例:

<xml>
   <appid>wx2421b1c4370ec43b</appid>
   <attach>支付测试</attach>
   <body>JSAPI支付测试</body>
   <mch_id>10000100</mch_id>
   <detail><![CDATA[{ "goods_detail":[ { "goods_id":"iphone6s_16G", "wxpay_goods_id":"1001", "goods_name":"iPhone6s 16G", "quantity":1, "price":528800, "goods_category":"123456", "body":"苹果手机" }, { "goods_id":"iphone6s_32G", "wxpay_goods_id":"1002", "goods_name":"iPhone6s 32G", "quantity":1, "price":608800, "goods_category":"123789", "body":"苹果手机" } ] }]]></detail>
   <nonce_str>1add1a30ac87aa2db72f57a2375d8fec</nonce_str>
   <notify_url>http://wxpay.wxutil.com/pub_v2/pay/notify.v2.php</notify_url>
   <openid>oUpF8uMuAJO_M2pxb1Q9zNjWeS6o</openid>
   <out_trade_no>1415659990</out_trade_no>
   <spbill_create_ip>14.23.150.211</spbill_create_ip>
   <total_fee>1</total_fee>
   <trade_type>JSAPI</trade_type>
   <sign>0CB01533B8C1EF103065174F50BCA001</sign>
</xml>

注:参数值用XML转义即可,CDATA标签用于说明数据不被XML解析器解析。

调用微信统一下单接口示例:

Controller:

    @ApiOperation(value = "创建JSAPI订单")
    @RequestMapping(value = "/order/create/jsapi", method = RequestMethod.GET)
    public JSONObject createJSAPI(
      @ApiParam(value = "openId", name = "openId") String openId,
      HttpServletRequest request) throws Exception {
   
      
        WechatUnifiedOrderRes wechatUnifiedOrderRes = wechatAppPayHandler.getJSAPIOrderRes(openId);
        logger.error("wechat createJSAPI wechatUnifiedOrderRes: {}", JSON.toJSONString(wechatUnifiedOrderRes));
        Map<String, String> res = new HashMap<>();
        res.put("payOrderId", payOrderId.toString());
        res.put("desc", payGoodsEnum.getGoodsName());
        String returnCode = wechatUnifiedOrderRes.getReturnCode();
        res.put("return_code", returnCode);
        res.put("return_msg", wechatUnifiedOrderRes.getReturnMsg().toString());
        if ("SUCCESS".equals(returnCode)) {
   
            res.put("nonce_str", wechatUnifiedOrderRes.getNonceStr());
            res.put("sign", wechatUnifiedOrderRes.getSign());
            String resultCode = wechatUnifiedOrderRes.getResultCode();
            res.put("result_code", resultCode);
            if ("SUCCESS".equals(resultCode)) {
   
                res.put("prepay_id", wechatUnifiedOrderRes.getPrepayId());
            } else {
   
                res.put("err_code", wechatUnifiedOrderRes.getErrCode()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信JSApi支付是指在微信公众或小程序内使用JSAPI调起微信支付功能,实现用户在微信内完成付款的一种方式。以下是常见的问题及解决方法: 1. 支付时提示“商户订单重复” 解决方法:修改商户订单,确保每笔订单的商户订单唯一。 2. 支付时提示“支付金额与订单金额不一致” 解决方法:检查订单金额和实际支付金额是否相同,确保订单金额与实际支付金额一致。 3. 支付时提示“支付失败,请稍后再试” 解决方法:检查支付参数是否正确,确保支付参数的完整性和准确性。 4. 支付时提示“当前用户未授权,请先授权登录” 解决方法:用户需要先授权登录,获取用户信息后才能进行支付操作。 5. 支付时提示“当前用户未关注公众” 解决方法:用户需要先关注公众,才能进行支付操作。 6. 支付时提示“商户与appid不匹配” 解决方法:检查商户和appid是否对应,确保商户和appid的匹配性。 7. 支付时提示“订单已关闭” 解决方法:订单可能已经被关闭或者已经完成支付,需要重新下单。 8. 支付时提示“系统繁忙,请稍后再试” 解决方法:服务器可能正在维护或者出现故障,需要等待一段时间后再尝试支付。 以上是微信JSApi支付常见问题及解决方法,如果以上方法无法解决问题,可以联系微信支付客服进行咨询。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值