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

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

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. C#值参数和引用参数

    一.值参数 未用ref或out修饰符声明的参数为值参数. 使用值参数,通过将实参的值复制到形参的方式,把数据传递到方法.方法被调用时,系统做如下操作. 在栈中为形参分配空间. 复制实参到形参. 值参数 ...

  2. CathyCMS-后台管理v1.0

    摘要: 最近开发CathyCMS系统作为练手项目,后台管理部分v1.0暂时告一段落.目前只包含了基本的登录.权限管理.频道管理.文章管理功能. 项目地址: https://github.com/cat ...

  3. 十、VueJs 填坑日记之在项目中使用Amaze UI

    上一篇博文,我们把jQuery集成到了项目中,今天我们来集成Amaze ui(妹子UI).先来介绍一下妹子UI.Amaze UI 含近 20 个 CSS 组件.20 余 JS 组件,更有多个包含不同主 ...

  4. react native android6+拍照闪退或重启的解决方案

    前言 android 6+权限使用的时候需要动态申请,那么在使用rn的时候要怎么处理拍照权限问题呢?本文提供的是一揽子rn操作相册.拍照的解决方案,请看正文的提高班部分. 解决步骤 1.Android ...

  5. You may rarely look at it. But you'll always feel it

    You may rarely look at it. But you'll always feel it

  6. ORACLE 错误代码提示归集

    有时数据库出现问题,不是每次都有网络可查,所以把所有的ora系列的错误整理出来, 在最没有办法的时候,需要自己来解决,有了这些根据,问题会好办的.虽说对于数据库方面, DBA很强大,他们在遇到错误时, ...

  7. ASP.NET Core 一步步搭建个人网站(持续更新中~~~)

    摘要 ASP.NET Core2.0发布有一阵子了,这是.NET 开源跨平台的一个重大里程碑, 也意味着比1.0版本要更加成熟.目前.net core具有开源.跨平台.灵活部署.模块化架构等等特性,吸 ...

  8. Less的内置函数

    杂项函数 color 解析颜色,将代表颜色的字符串转换为颜色值. 参数: string: 代表颜色值的字符串. 返回值: color 案例: color("#aaa"); 输出: ...

  9. jQuery中使用$.each()遍历后台响应的json字符串问题

    今天在做练习项目的时候,使用$.each()方法遍历后台传过来的json字符串时,chrome浏览器中发现如下问题  Cannot use 'in' operator to search for 'l ...

  10. 用python批量修改文件名

    从youtube上当下来百来首mv,每个都需要去掉视频,这还挺好弄得,格式工厂一弄就完了,但是文件名,都带有乱七八糟的*啥的巴拉巴拉的,咋修改啊,几百首总不可能一个一个rename吧 #批量修改文件名 ...