微信扫码i支付~官方DEMO的坑

简介:

之前写过关于微信支付那些坑的文章(《微信JSApi支付~集成到MVC环境后的最后一个坑(网上没有这种解决方案)》,《微信JSApi支付~坑和如何填坑》),下面说一下微信官方提供的"扫码支付",一配置,一运行,生成了一个二维码,手机一扫,出现了"获取商户订单信息超时或商户返回httpcode非200",在百度上一问,都是说签名错误,当然我的签名一定没错,所以,还要自己找问题,经过了一翻测试与日志,终于找到了一个点,那就是关于字典类型的对象的判断上,判断一个没不在的键,然后使用这个键,然后就是失败,连异常都不报,晕!

下面是关于扫码支持用到的文件

简单说一下这几个文件的功能

NativePayPage.aspx:扫码支付发起页面

NativeNotifyPage.aspx:由微信服务端进行回调的页面,这个在公众平台进行设置(微信支持->开发设置->权限目录;微信支持->开发设置->支付回调)

ResultNotifyPage.aspx:处理微信订单信息,在WxPayConfig类里进行配置

最后,我们将官方的DEMO里的BUG注释一下, 支付就可以成功了

文件:WxPayData类的FromXml方法,把对应的代码注释即可,因为这时,m_values字典里根本没有return_code键,所以不能处理成功.

对于知识的研究,我们有时确实要多加后日志,请不要太相信大公司写的公开API,它们可能也有BUG!

后记扫码支付的两种模式

模式1开发流程:
1、生成二维码(https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=6_4),给买家扫码
2、回调到上图设置的回调的URL当中,得到必要的参数,调用统一下单API,生成参数,提交到微信接口,并把这些参数保存到数据库(最重要的是 商户订单号,此订单号再微信支付成功异步回调中,会返回这个订单号,也就是说,订单号是此条数据的唯一标识)
3、步骤2中统一下单会返回一个 code_url(二维码连接),生成二维码,给买家扫码
4、买家打开微信扫码,支付完成。
5、微信进入回调的url (该回调的URL在下单的API的参数中)
6、在回调的接口中获取微信传过来的参数。根据商户订单号--修改数据库的数据。 推送到APP成功的状态

模式2开发流程:
1、调用统一下单API,生成参数,提交到微信接口,并把这些参数保存到数据库(最重要的是商户订单号,此订单号再微信支付成功异步回调中,会返回这个订单号,也就是说,订单号是此条数据的唯一标识)
2、步骤2中统一下单会返回一个 code_url(二维码连接),生成二维码,给买家扫码
3、买家打开微信扫码,支付完成。
4、微信进入回调的url (该回调的URL在下单的API的参数中)
5、在回调的接口中获取微信传过来的参数。根据商户订单号--修改数据库的数据。 推送到APP成功的状态
本文转自博客园张占岭(仓储大叔)的博客,原文链接: 微信扫码i支付~官方DEMO的坑 ,如需转载请自行联系原博主。
目录
相关文章
|
11天前
|
移动开发 JavaScript
Vue——H5微信内支付(四)
10月更文挑战第11天
31 2
|
17天前
|
移动开发 JavaScript 前端开发
Vue——H5微信内支付(一)
10月更文挑战第8天
35 1
|
10天前
|
移动开发 前端开发
|
11天前
|
移动开发 JavaScript
Vue——H5微信内支付(五)
10月更文挑战第12天
20 2
|
13天前
|
移动开发 JavaScript
Vue——H5微信内支付(三)
10月更文挑战第10天
32 1
|
16天前
|
移动开发 JavaScript
Vue——H5微信内支付(二)
10月更文挑战第9天
27 1
|
19天前
|
移动开发 安全 API
微信H5支付--微信JS-SDK支付--点金计划
本文详细介绍了微信H5支付和JS-SDK支付的原理、配置和开发流程,涵盖了H5支付在移动端浏览器外唤起微信支付的细节,以及JS-SDK支付在微信内置浏览器中完成支付的相关注意事项。文章还针对微信支付常见问题,提供了解决方案和代码示例。最后,文章深入解析了微信支付点金计划,包括商家小票的自定义开发、API接口以及支付成功后的页面展示逻辑,为开发者提供了完整的开发参考。
18 0
微信H5支付--微信JS-SDK支付--点金计划
|
25天前
|
Web App开发 移动开发 前端开发
H5微信外支付(移动端浏览器)
H5微信外支付(移动端浏览器)
34 0
 H5微信外支付(移动端浏览器)
|
6天前
|
移动开发
|
9天前
|
Web App开发 移动开发 Android开发