微信小程序进行微信支付的步骤昂述


Posted in Javascript onDecember 01, 2016

最近开发微信小程序进入到支付阶段,一直以来从事App开发,所以支付流程还是熟记于心的。但是微信小程序的支付就有点奇怪了,应用的创建是在公众号里,但是文档的介绍却在公众号中无法找到直接入口,甚是不解,而且小程序的师傅到底是属于公众号支付范畴还是app支付范畴也成疑问。下面是小程序支付文档的入口(嵌套在小程序api中):

https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1

小程序支付步骤:

1,预支付

2,根据预支付数据+签名——>发起支付

3,支付回调

下面对这3个步骤进行简单描述:

1,预支付。该接口通过前端提交需支付的信息(订单号、价格等)给开发者服务器,开发者服务器在提交到微信,而后返回真正前端需要进行支付的一些信息;eg:

开发者服务器的预支付接口:

https://()htm?total_fee=100&cid=6001&orderCodes=2016120119
{
"sign":"A2****************A6",
"timestamp":"14****************68",
"package":"Sign=WXPay",
"partnerId":"14****************02",
"appid":"wx****************ab",
"nonceStr":"9f****************37",
"prepayId":"wx****************54"
}

2,发起支付(需要注意的是发起支付是不需要上传appid,

但是签名paySign需要appid ,而且放在第一个)

wx.requestPayment({ 
nonceStr: res.data.nonceStr, 
package: "prepay_id="+res.data.prepayId, 
signType: 'MD5', 
timeStamp: res.data.timestamp, 
paySign: sign,//<strong><span style="color:#ff0000;">五个字段参与签名(区分大小写):appId,nonceStr,package,signType,timeStamp(需要注意的是,这5个参数签名排序的顺序按照ASCII字典序排序)</span></strong> 
success: function(res){ 
console.log("支付成功"); 
}, 
fail: function() { 
}, 
complete: function() { 
} 
})

生成签名sign

https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1&t=20161122

微信小程序MD5加密工具下载地址:https://code.csdn.net/snippets/2019875/master/download

var MD5Util = require('../../../utils/md5.js');
var sign = ''; 
//<strong><span style="color:#ff0000;">顺序按照ASCII字典序排序</span></strong> 
var signA = "appId="+app.appId+"&nonceStr="+res.data.nonceStr+"&package=prepay_id="+res.data.prepayId+"&signType=MD5&timeStamp="+res.data.timestamp; 
var signB = signA+"&key="+app.key; 
sign = MD5Util.MD5(signB).toUpperCase();

生成签名上面是我的代码,不是很清晰, 下面列出来官方文档的详细描述:

假设传送的参数如下:

appid: wxd930ea5d5a258f4f(需要注意的是appid 在wx.requestPayment({})发起支付是不上传,但是签名时需要)
mch_id: 10000100
device_info: 1000
body: test
nonce_str: ibuaiVcKdpRxkhJA

第一步:对参数按照key=value的格式,并按照参数名ASCII字典序排序如下:

stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=10000100&nonce_str=ibuaiVcKdpRxkhJA";

第二步:拼接API密钥:

stringSignTemp="stringA&key=192006250b4c09247ec02edce69f6a2d"
sign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A9CF3B7"

此时的sign 用于wx.requestPayment 上传参数paySign。

最终得到最终发送的数据:

<xml> 
<appid>wxd930ea5d5a258f4f</appid> 
<mch_id>10000100</mch_id> 
<device_info>1000<device_info> 
<body>test</body> 
<nonce_str>ibuaiVcKdpRxkhJA</nonce_str> 
<sign>9A0A8659F005D6984697E2CA0A9CF3B7</sign> 
<xml>

以上所述是小编给大家介绍的微信小程序进行微信支付的步骤,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jQuery 行级解析读取XML文件(附源码)
Oct 12 Javascript
jQuery的live()方法对hover事件的处理示例
Feb 27 Javascript
Bootstrap实现带动画过渡的弹出框
Aug 09 Javascript
js接收并转化Java中的数组对象的方法
Aug 11 Javascript
jQuery事件绑定用法详解
Sep 08 Javascript
jQuery居中元素scrollleft计算方法示例
Jan 16 Javascript
AngularJS 的$timeout服务示例代码
Sep 21 Javascript
JavaScript中创建原子的方法总结
Aug 26 Javascript
JS通过识别id、value值对checkbox设置选中状态
Feb 19 Javascript
vue实现一个6个输入框的验证码输入组件功能的实例代码
Jun 29 Javascript
Vue路由切换页面不更新问题解决方案
Jul 10 Javascript
解决vue2中使用elementUi打包报错的问题
Sep 22 Javascript
第一次接触神奇的前端框架vue.js
Dec 01 #Javascript
bootstrapValidator自定验证方法写法
Dec 01 #Javascript
jQuery生成假加载动画效果
Dec 01 #Javascript
解析AngularJS中get请求URL出现的跨域问题
Dec 01 #Javascript
浅谈js键盘事件全面控制
Dec 01 #Javascript
jstree的简单实例
Dec 01 #Javascript
Vue.JS入门教程之事件监听
Dec 01 #Javascript
You might like
星际争霸兵种名称对照表
2020/03/04 星际争霸
mysql4.1以上版本连接时出现Client does not support authentication protocol问题解决办法
2007/03/15 PHP
在SAE上搭建最新wordpress的方法
2014/12/21 PHP
用js实现计算代码行数的简单方法附代码
2007/08/13 Javascript
getElementsByTagName vs selectNodes效率 及兼容的selectNodes实现
2010/02/26 Javascript
jQuery学习笔记之DOM对象和jQuery对象
2010/12/22 Javascript
js中将HTMLCollection/NodeList/伪数组转换成数组的代码
2011/07/31 Javascript
javascript检测页面是否缩放的小例子
2013/05/16 Javascript
限制文本框只能输入数字||只能是数字和小数点||只能是整数和浮点数
2016/05/27 Javascript
url中的特殊符号有什么含义(推荐)
2016/06/17 Javascript
基于vuejs+webpack的日期选择插件
2020/05/21 Javascript
利用纯JS实现像素逐渐显示的方法示例
2017/08/14 Javascript
JS+CSS实现网页加载中的动画效果
2017/10/27 Javascript
详解vue表单——小白速看
2018/04/08 Javascript
详解ajax的data参数错误导致页面崩溃
2018/04/30 Javascript
javascript将非数值转换为数值
2018/09/13 Javascript
微信小程序rich-text富文本用法实例分析
2019/05/20 Javascript
Vue 实现从文件中获取文本信息的方法详解
2019/10/16 Javascript
vue 实现tab切换保持数据状态
2020/07/21 Javascript
Vue toFixed保留两位小数的3种方式
2020/10/23 Javascript
Python使用代理抓取网站图片(多线程)
2014/03/14 Python
python中enumerate函数遍历元素用法分析
2016/03/11 Python
python命令行解析之parse_known_args()函数和parse_args()使用区别介绍
2018/01/24 Python
python 2.7 检测一个网页是否能正常访问的方法
2018/12/26 Python
Python可变和不可变、类的私有属性实例分析
2019/05/31 Python
Python匿名函数/排序函数/过滤函数/映射函数/递归/二分法
2019/06/05 Python
Python 3 实现定义跨模块的全局变量和使用教程
2019/07/07 Python
Python中BeautifuSoup库的用法使用详解
2019/11/15 Python
Python vtk读取并显示dicom文件示例
2020/01/13 Python
Python对称的二叉树多种思路实现方法
2020/02/28 Python
CSS3自定义滚动条样式 ::webkit-scrollbar的示例代码详解
2020/06/01 HTML / CSS
宝信软件JAVA工程师面试经历
2012/08/19 面试题
党的群众路线教育实践活动个人整改方案
2014/10/25 职场文书
2016教师学习党章心得体会
2016/01/15 职场文书
浅谈mysql执行过程以及顺序
2021/05/12 MySQL
win11怎么消除图标小盾牌?win11消除图标小盾牌解决方法
2022/08/05 数码科技