首頁  >  文章  >  web前端  >  如何用微信小程式發紅包

如何用微信小程式發紅包

yulia
yulia原創
2018-09-10 15:11:026459瀏覽

在目前的小程式版本尚不支援發紅包這個功能,開發者們表面笑嘻嘻,心裡媽賣批! 在這裡,提供一種已經實踐過的解決思路。

詳細解析,就是下面的幾個步驟

1、首先是在小程式裡面的領紅包入口
2、點擊後跳轉webview, 附帶當前的小程式的token給webview驗證,webview 的src 指向具備付款能力的服務號的一個獲取openid頁面,根據附加的token來判斷用戶是否可以領取紅包,此時用戶擁有兩個openid,一個是相對於小程式的openid,一個是相對於服務號碼的用來發紅包的openid,如下面偽代碼   

// 伪代码
    weixinApi.angerPay.sendRedPacket({
      total_num: 1,
      mch_billno: '1000000',
      send_name: '测试标题',
      re_openid: 'xaxadsadas', // 获取到的openid
      total_amount: 100,
      wishing: '恭喜发财,大吉大利',
      act_name: '扫码领红包',
      remark: '备注信息',
      client_ip: '127.0.0.1',
      scene_id: 'PRODUCT_2'
      }, (err, result) => {
      console.log(err, result)
  });

3、回傳領取結果


############# #注意事項#########1、跳轉的webview的src要加入到小程式業務網域###2、連結必須是https 協定的#########未來的接口#########在不久的將來,會開放一個發紅包的接口,就是wx.sendBizRedPacket,用法實例。 ###
   wx.sendBizRedPacket({
      timeStamp: e.timeStamp,
      nonceStr: e.nonceStr,
      package: e.package,
      signType: e.signType,
      paySign: e.paySign,
      success: function (res) {
        console.log('红包success')
        let url = config.HTTP_Prize_URL + '/v1/sign_tmp/sendSuccess.do';
        let data = {
          minipid: that.data.minipid,
          date: that.data.date
        }
        console.log('红包成功以后接口请求参数数据:' + JSON.stringify(data))
        util.request(url, 'post', data, '正在加载数据', function (res) {
          console.log('红包成功以后接口返回结果:' + JSON.stringify(res.data))
        })
        wx.reLaunch({
          url: '../my_prize/my_prize_2?reward=' + res.data.body.reward,
        })
      },
      fail: function (res) {
        console.log('红包fail')
      },
      complete: function (res) {
        console.log('红包complete')
        // wx.showModal({
        //   title: '红包complete',
        //   content: '红包complete',
        // })
      }
    })

以上是如何用微信小程式發紅包的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn