这个讲起来也就比较麻烦一点,因为需要的不仅仅是咱们代码上的技术,嘿嘿!

先整理一下思路。如果想做微信支付:

1.现有一个公司账户(非个人账户),并且实名认证过的。

2.微信号 必须开通微信支付功能。

3.开发者ID。

4.小程序秘钥。

5.开发者工具。嘿嘿!

从现在开始说小程序的 支付步骤(大概分三步):

1.获取微信账号的openID

这个在app.js 会有系统注释,然你在那个位置书写对应的代码:

https://api.weixin.qq.com/sns/jscode2session
参数:
appid:'',//开发者id
secret:'',//小程序的秘钥
grant_type:'authorization_code',//固定
js_code:res.code //登录接口返回的值
这个为获取 openid 的访问地址,不过不要急着写,因为他被微信小程序认定为,不可靠连接,所以还是需要让自己家后台包装一下。再去访问

下面是代码:(openid就是在app.js中登录成功代码内再次获取,一般存储在全局变量 globalData中)
 var url = this.globalData.hostIP + "你们家后台域名地址?";
url += 'appid=' + '开发者id';
url += '&secret=' + '秘钥';
url += '&grant_type=' + 'authorization_code';
url += '&js_code=' + res.code;
wx.request({
url: url,
method: 'GET',
header: { 'content-type': 'text/html;charset=UTF-8' },
success: function (openIdRes) {
console.info("登录成功返回的openId:" + openIdRes.data.Obj.openid);
// 判断openId是否获取成功
if (openIdRes.data.Obj.openid != null & openIdRes.data.Obj.openid != undefined) {
// 有一点需要注意 询问用户 是否授权 那提示 是这API发出的
wx.getUserInfo({
success: function (data) {
// 自定义操作
// 绑定数据,渲染页面
that.globalData.weChatUserInfo = data;
},
fail: function (failData) {
console.info("用户拒绝授权");
}
});
} else {
console.info("获取用户openId失败");
}
},
fail: function (error) {
console.info("获取用户openId失败");
console.info(error);
}
})

2.微信统一下单

这一步微信统一下单  其实也是需要公司自己后台集成的,不过咱们个人实验的话,可以直接写在js页面中,原因就是他有一个参数  notify_url  顾名思义,就是 通知地址  也就是 回调地址,嘿!

统一下单接口地址:https://api.mch.weixin.qq.com/pay/unifiedorder

然后他的参数就多了去了,然后下面的示例代码就是咱们个人实验的了:(因为订单参数中时间 要 20091225091010 的格式 所有 用的自己方法  formatTime2, 当然你也可以随便编一个嘿!

ps:(然后,订单参数  时间方法 你可以用 去找我 微信小程序路过——新手不要错过哦! 这个文章 看看  我介绍的时间格式如何修改方法 )

 //微信支付 统一下单  接口
wx_pay: function (e) { var that = this;//获取当前 var nonce_str = Math.random().toString(36).substr(2, 15);//随机生成签证
var time_start = util.formatTime2(new Date());//订单日期
var time_expire = this.getoutTime();//订单结束日期 指定多长时间后 现在15天
//拼接参数
var data = {
appid: '开发者ID',
mch_id: '商户号', //收费着账号
device_info: 'WEB',//默认这个
nonce_str: nonce_str,
sign: '',
sign_type: 'MD5',
body: '商品描述',
detail: '商品详细',
attach: '附加数据',
out_trade_no: '自己后台的订单号',
fee_type: 'CNY', 货币种类 人民币
total_fee: '0.1', 总金额
spbill_create_ip: '123.12.12.123',随便填一个
time_start: time_start, 订单开始时间
time_expire: time_expire, 订单结束时间
goods_tag: 'WXG',默认这个
notify_url: 'http://www.baidu.com',回调方法 随便写一个,不报错就行
trade_type: 'JSAPI',默认这个
limit_pay: 'no_credit',支付方式-不能使用信用卡
openid: '前面获取的openid',
};
data['sign'] = this.GetSign(data);// 重新设置 签名
var xml = this.getXml(data);//json 转为xml //获取 用户 prepay_id
wx.request({
url: 'https://api.mch.weixin.qq.com/pay/unifiedorder',
header: {
"Content-Type": "application/XML" 看这里看这里
},
method: "POST",
data: xml,
complete: function (res) { //获取参数 id 获取的参数 为XML 类型
var xmlParser = new Parser.DOMParser();
var doc = xmlParser.parseFromString(xml);
var prepay_id = doc.getElementsByTagName("prepay_id")[0].firstChild.nodeValue; if (res == null || res.data == null) {
wx.showToast({
title: '网络错误!',
icon: 'loading',
duration: 1500
})
return;
}
}
}) },

看到上面是不是感觉参数很麻烦。嘿, 有两个调用方法我放在下面哈!

  /**
* 生成签名方法
*/
GetSign: function (json) {
var arrs = new Array();
for (var key in json) {
if (key != 'sign') {
arrs.push(key + "=" + json[key] + "&");
}
}
arrs = arrs.sort();
var s = "";
for (var item in arrs) {
s += item;
}
s = s.substring(0, s.length - 1); s += "&key=这里填写自己的秘钥";
s = utilMd5.hexMD5(s).toUpperCase();
return s;
},
/**
* 订单超时方法
*/
getoutTime: function () {
//订单结束日期
var timestamp = Date.parse(new Date());
timestamp = timestamp / 1000;
var tomorrow_timetamp = timestamp + 15 * 60;
var n_to = tomorrow_timetamp * 1000;
var end_date = new Date(n_to); return util.formatTime2(new Date(end_date));
},

这样 就可以 调试一下 统一下单咯,试试 是否能成功。

住一段最重要的就是签名  他需要把所有参数不包括(sign)按照ASCII字典序排,然后组成 key=value的格式 格式,不过小编的方法已经具备这个功能了,剩下的就是要 MD5 加密一下,

小程序本身也提供一个加密工具来对照一下(https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=4_3)

MD5加密的话 我建议(https://www.cnblogs.com/chenxiaojun/p/7155236.html)直接拿 陈小俊小哥哥的  代码,在utils 文件夹下创建一个js

然后在  统一下单界面引用实例化一下  var utilMd5 = require('../../utils/MD5加密文件名.js'); 就可以

3.获取支付(弹出支付界面)

然后就是咱们最后一步微信支付咯!

ps:如果,提示你 没有权限,那你一定是没有完成 商户认证或者 支付认真 ,毕竟需要300块 自己实验到这一步就可以了。

人家微信小程序已经给咱们封装好了这个方法:(https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_7&index=5    看一下官方api)

wx.requestPayment(OBJECT) 方法直接就能调用了

不过要看清楚咯 ! 小程序调起支付数据签名字段列表 不是跟统一下单一样,现在是要签名一下参数的:

小程序ID appId String wxd678efh567hg6787 微信分配的小程序ID
时间戳 timeStamp String 1490840662 时间戳从1970年1月1日00:00:00至今的秒数,即当前的时间
随机串 nonceStr String 5K8264ILTKCH16CQ2502SI8ZNMTM67VS 随机字符串,不长于32位。推荐随机数生成算法
数据包 package String prepay_id=wx2017033010242291fcfe0db70013231072 统一下单接口返回的 prepay_id 参数值,提交格式如:prepay_id=wx2017033010242291fcfe0db70013231072
签名方式 signType String MD5

这几个参数  不过这个签名方式 还是如同咱们上面的那个签名方法,嘿赶快去试试吧。(注意咯,真是开发使用 也要判断你用户取消 支付哦!)

有觉得不清晰的老铁,说出模糊点留言,我做修改,来完善阅读体验!!!!

微信小程序——微信支付的更多相关文章

  1. 微信小程序篇(微信小程序的支付)

    微信小程序的支付和微信公众号的支付是类似的,对比起来还比公众号支付简单了一些,我们只需要调用微信的统一下单接口获取prepay_id之后我们在调用微信的支付即可. 今天我们来封装一般node的支付接口 ...

  2. 【微信小程序】支付过程详解

    一.介绍 今天跟大家分享微信小程序集成支付. 二.分析 1.小程序支付API 地址:https://mp.weixin.qq.com/debug/wxadoc/dev/api/api-pay.html ...

  3. 微信小程序在线支付功能使用总结

    最近需要在微信小程序中用到在线支付功能,于是看了一下官方的文档,发现要在小程序里实现微信支付还是很方便的,如果你以前开发过服务号下的微信支付,那么你会发现其实小程序里的微信支付和服务号里的开发过程如出 ...

  4. 微信小程序—微信自动退款

    微信小程序—微信自动退款 一.业务背景 微信自动退款串接基于酷客多小程序商城系统,为方便财务人员进行订单退款而开发,将酷客多小程序系统财务退款流程和微信退款系统打通.实现一个系统管理运营. 二.业务流 ...

  5. 微信小程序-微信自动退款(Java后台)

    微信小程序-微信自动退款 1.首先分享 微信自动退款接口: https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_4 微信付款 代码案例 ...

  6. 微信小程序+微信管理后台+微信用户前台

    代码地址如下:http://www.demodashi.com/demo/15043.html #### 微信小程序+微信管理后台+微信用户前台 #### 产品介绍 基础功能开发:景区微信地图导游.天 ...

  7. 微信小程序实现支付功能

    小程序支付,没有封装支付代码:直接上一段可用的流程代码吧:微信小程序支付官网文档有详细的说明,这里我就不再赘述啦:客户端js: wx.request({ url:'https://www.xxxx.c ...

  8. java微信小程序调用支付接口(转)

    简介:微信小程序支付这里的坑还是有的,所以提醒各位在编写的一定要注意!!! 1.首先呢,你需要准备openid,appid,还有申请微信支付后要设置一个32位的密钥,需要先生成一个sign,得到pre ...

  9. java微信小程序调用支付接口

    简介:微信小程序支付这里的坑还是有的,所以提醒各位在编写的一定要注意!!! 1.首先呢,你需要准备openid,appid,还有申请微信支付后要设置一个32位的密钥,需要先生成一个sign,得到pre ...

随机推荐

  1. [转载] 一致性hash算法释义

    转载自http://www.cnblogs.com/haippy/archive/2011/12/10/2282943.html 一致性Hash算法背景 一致性哈希算法在1997年由麻省理工学院的Ka ...

  2. spring4+srpingmvc+mybatis基本框架(app后台框架搭建一)

    前言: 随着spring 越来越强大,用spring4来搭建框架也是很快速,问题是你是对spring了解有多深入.如果你是新手,那么在搭建的过程中可以遇到各种各样奇葩的问题. SSM框架的搭建是作为我 ...

  3. 【Win 10 应用开发】UI Composition 札记(七):基于表达式的动画

    上一篇烂文中,老周给大伙伴们介绍过了几个比较好玩的动画.本篇咱们深化主题,说一说基于表达式的动画.这名字好理解,就是你可以用公式 / 等式来产生动画的目标值.比如,你想让某个可视化对象的高度减半,你的 ...

  4. 【转载】 Java:按值传递还是按引用传递详细解说

    前天在做系统的时候被Java中参数传递问题卡了一下,回头查阅了相关的资料,对参数传递问题有了新的了解和掌握,但是有个问题感觉还是很模糊,就是Java中到底是否只存在值传递,因为在查阅资料时,经常看到有 ...

  5. springboot使用i18n时properties文件中文乱码

    在springboot使用i18n进行国际化文件配置时,文件名为messages_zh_CN.properties的文件中填写中文信息,当使用浏览器进行访问时,出现中文乱码,此时在idea中进行修改s ...

  6. # WPF动画速率效果

    在WPF中使用动画的情况非常多,而要让动画变得生动往往要使用一些变速动画,WPF也内置了很方便的缓动函数来实现这一功能. 除此之外,WPF还有关键帧动画,利用关键帧动画能够很好的控制动画的细节,与美工 ...

  7. SpringCloud学习笔记(2)——Ribbon

    参考SpringCloud官网第16.17章 16. Client Side Load Balancer: Ribbon Ribbon是一个客户端的负载均衡器,它提供对大量的HTTP和TCP客户端的访 ...

  8. 非一屏页面,出现遮罩层页面位置不动,并且遮罩层一屏显示。(pc,移动端都适用的方法)

    首先展示页面效果: 遮罩没出现的页面张酱紫:页面在楼层二这个位置. 遮罩显示:后面页面页面任停留在当前浏览位置,滚动条并未回顶部 下面来说说写法: css: 页面具体布局样式......(此处省略无数 ...

  9. centOS 搭建pipelineDB docs

    #下载docs git clone https://github.com/pipelinedb/docs.git #安装python-sphinx &python-dev yum instal ...

  10. Redis的五种数据类型及方法

    字符串string: 字符串类型是Redis中最为基础的数据存储类型,是一个由字节组成的序列,他在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据货Json对象描 ...