jweixin.js 4.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. // #ifdef H5
  2. const jweixin = require('public/jweixin-module/jweixin-module.js')
  3. const debug = false; // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  4. /**
  5. * 微信公众号h5支持方法封装
  6. */
  7. const payRequest = (payData, callback, failCallback) => {
  8. jweixin.config({
  9. debug: debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  10. appId: payData.appId, // 必填,公众号的唯一标识
  11. timestamp: payData.timeStamp, // 必填,生成签名的时间戳
  12. nonceStr: payData.nonceStr, // 必填,生成签名的随机串
  13. signature: payData.paySign, // 必填,签名,见附录1
  14. jsApiList: ['chooseWXPay'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
  15. });
  16. jweixin.ready(function () {
  17. jweixin.chooseWXPay({
  18. timestamp: payData.timeStamp, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
  19. nonceStr: payData.nonceStr, // 支付签名随机串,不长于 32 位
  20. package: payData.packageValue, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
  21. signType: payData.signType, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
  22. paySign: payData.paySign, // 支付签名
  23. success: function (res) {
  24. // 支付成功后的回调函数
  25. callback(res);
  26. },
  27. cancel: function (res) {
  28. // cancelCallback(res);
  29. },
  30. fail: function (res) {
  31. failCallback(res);
  32. }
  33. });
  34. });
  35. jweixin.error(function (res) {
  36. console.log('error')
  37. console.log(res)
  38. uni.showToast({
  39. icon: 'none',
  40. title: '支付失败了',
  41. duration: 4000
  42. });
  43. // config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
  44. /*alert("config信息验证失败");*/
  45. });
  46. }
  47. // 分享链接给微信朋友,
  48. const shareWxFriend = (configObj, shareObj, callback, failCallback) => {
  49. jweixin.config({
  50. debug: debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  51. appId: configObj.appId, // 必填,公众号的唯一标识
  52. timestamp: configObj.timestamp, // 必填,生成签名的时间戳
  53. nonceStr: configObj.nonceStr, // 必填,生成签名的随机串
  54. signature: configObj.signature, // 必填,签名,见附录1
  55. jsApiList: ['updateTimelineShareData', 'updateAppMessageShareData'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
  56. });
  57. jweixin.ready(function (res) {
  58. jweixin.updateAppMessageShareData({
  59. title: shareObj.title, // 分享标题
  60. desc: shareObj.desc, // 分享描述
  61. link: shareObj.link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
  62. imgUrl: shareObj.imgUrl, // 分享图标
  63. success: function () {
  64. // callback();
  65. }
  66. })
  67. jweixin.updateTimelineShareData({
  68. title: shareObj.title, // 分享标题
  69. desc: shareObj.desc, // 分享描述
  70. link: shareObj.link, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
  71. imgUrl: shareObj.imgUrl, // 分享图标
  72. success: function () {
  73. callback();
  74. }
  75. })
  76. });
  77. }
  78. module.exports = {
  79. payRequest: payRequest,
  80. shareWxFriend: shareWxFriend,
  81. };
  82. // #endif