微信公众号支付
微信公众号支付
微信公众号支付 wechat office account
1. 使用场景
商户已有H5商城网站,用户通过消息或扫描二维码在微信内打开网页时,可以调用微信支付完成下单购买的流程。
步骤(1):如图7.1,商户下发图文消息或者通过自定义菜单吸引用户点击进入商户网页。
步骤(2):如图7.2,进入商户网页,用户选择购买,完成选购流程。
步骤(3):如图7.3,调起微信支付控件,用户开始输入支付密码。
步骤(4):如图7.4,密码验证通过,支付成功。商户后台得到支付成功的通知。
2. 开发步骤
2.1. 设置支付授权目录
提供需要调用支付的域名给UseePay进行配置
2.2. 设置页面授权域名
开发公众号支付时,在下单接口中要求必传用户openid,而获取openid则需要您在公众平台设置获取openid的域名,只有被设置过的域名才是一个有效的获取openid的域名,否则将获取失败。具体界面如图7.8所示:
2.3业务流程时序图
商户与UseePay系统主要交互:
1.商户Server 调用Jsapi支付下单接口
2.商户Server接受支付通知
3.商户Server查询支付结果
3. Pay接口
请查看Jsapi支付下单接口
4. 如何获取openId
请查看微信授权
5. 微信H5调起支付
在微信浏览器里面打开H5网页中执行JS调起支付。接口输入输出数据格式为JSON。
注意:WeixinJSBridge内置对象在其他浏览器中无效。
列表中参数名区分大小,大小写错误签名验证会失败。
getBrandWCPayRequest参数以及返回值定义如下:
网页内支付接口err_msg返回结果值说明:
WeixinJSBridge.invoke(
'getBrandWCPayRequest',{
"appId":"wx2421b1c4370ec43b",//公众号名称,由商户传入
"timeStamp":"1395712654", //时间戳,自1970年以来的秒数
"nonceStr":"e61463f8efa94090b1f366cccfbbb444",//随机串
"package":"prepay_id=u802345jgfjsdfgsdg888",
"signType":"RSA", //微信签名方式:
"paySign":"70EA570631E4BB79628FBCA90534C63FF7FADD89"//微信签名
},
function(res){
if(res.err_msg === "get_brand_wcpay_request:ok" ) {
// 使用以上方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回 ok,但并不保证它绝对可靠。
alert("支付成功");
}
}
)
返回值 | 描述 |
---|---|
get_brand_wcpay_request:ok | 支付成功 |
get_brand_wcpay_request:cancel | 支付过程中用户取消 |
get_brand_wcpay_request:fail | 支付失败 |
JS API的返回结果get_brand_wcpay_request:ok仅在用户成功完成支付时返回。由于前端交互复杂,get_brand_wcpay_request:cancel或者get_brand_wcpay_request:fail可以统一处理为用户遇到错误或者主动放弃,不必细化区分
最后修改时间: 1 年前