微信小程式模板發送,openid獲取,以及api.weixin.qq.com不在合法功能變數名稱內解決方法

来源:https://www.cnblogs.com/koumeng/archive/2018/02/24/8466184.html
-Advertisement-
Play Games

本文主要解決個人開發者模板消息發送的問題(沒有伺服器,不能操作伺服器的情況) 針對api.weinxin.qq.com不在以下合法功能變數名稱列表內的問題提出的解決方案 ...


主要內容在標題三,老手可直接跳到標題三。

本文主要解決個人開發者模板消息發送的問題(沒有伺服器,不能操作伺服器的情況)

針對api.weinxin.qq.com不在以下合法功能變數名稱列表內的問題提出的解決方案

一、入門

按照以下網址教程註冊一個小程式賬號,安裝開發工具等一併安裝完成。

https://mp.weixin.qq.com/debug/wxadoc/dev/index.html?t=201828

 

 

 

將上圖中的appid和appSecret,複製保存下來,appid可以每次登陸上述網頁查看,但appSecret只有重置。建議appid和appSecret複製粘貼到一個txt文件中,以後經常會用到。利用appid就可以建立小程式了。

 

在這裡到發送模板消息之間還需要學習,請自行補相關知識。

 

二、模板信息

以下網址是微信對模板信息的官方解釋,

https://mp.weixin.qq.com/debug/wxadoc/dev/api/notice.html

 

2.1模板發送條件

  1、 支付:當用戶在小程式內完成過支付行為,可允許開發者向用戶在7天內推送有限條數的模板消息(1次支付可下發1條,多次支付下發條數獨立,互相不影響) 
2、提交表單:當用戶在小程式內發生過提交表單行為且該表單聲明為要發模板消息的,開發者需要向用戶提供服務時,可允許開發者向用戶在7天內推送有限條數的模板消息(1次提交表單可下發1條,多次提交下發條數獨立,相互不影響)

 

2.2主要步驟為以下三條

步驟1

主要是保存模板ID,建議和appid一樣,複製粘貼到txt文件,保留以備後面使用

 

步驟2.就是滿足模板信息發送的兩個條件之一。這裡用表單作為示例。

 

<form bindsubmit="formSubmit" report-submit='true'> //主要是這行代碼要有

 

  <!-- <button form-type='submit'>submit</button> -->

    <view class="weui-dialog__btn weui-dialog__btn_default" bindtap="noneWindows">取消</view>

    <button loading="{{loading}}" class="weui-dialog__btn weui-dialog__btn_primary" formType="submit">提交</button>  //然後在有個按鈕就行了

  </view>

</form>

 <button type='primary' bindtap='zhuce'>註冊</button>   //用來獲取openid的按鈕,openid的內容後續會講解

 

步驟3 模板信息的發送

按照教程轉到發送模板消息

 

2.3 模板信息的發送

模板信息的發送分兩步

2.3.1、獲取token

access_token 是全局唯一介面調用憑據,開發者調用各介面時都需使用 access_token,請妥善保存。access_token 的存儲至少要保留512個字元空間。access_token 的有效期目前為2個小時,需定時刷新,重覆獲取將導致上次獲取的 access_token 失效。

公眾平臺的 API 調用所需的 access_token 的使用及生成方式說明:

為了保密 appsecrect,第三方需要一個 access_token 獲取和刷新的中控伺服器。而其他業務邏輯伺服器所使用的 access_token 均來自於該中控伺服器,不應該各自去刷新,否則會造成 access_token 覆蓋而影響業務;

目前 access_token 的有效期通過返回的 expires_in 來傳達,目前是7200秒之內的值。中控伺服器需要根據這個有效時間提前去刷新新 access_token。在刷新過程中,中控伺服器對外輸出的依然是老 access_token,此時公眾平臺後臺會保證在刷新短時間內,新老 access_token 都可用,這保證了第三方業務的平滑過渡;

access_token 的有效時間可能會在未來有調整,所以中控伺服器不僅需要內部定時主動刷新,還需要提供被動刷新 access_token 的介面,這樣便於業務伺服器在 API 調用獲知 access_token 已超時的情況下,可以觸發 access_token 的刷新流程。

開發者可以使用 AppID 和 AppSecret 調用本介面來獲取 access_token。AppID 和 AppSecret 可登錄微信公眾平臺官網-設置-開發設置中獲得(需要已經綁定成為開發者,且帳號沒有異常狀態)。AppSecret 生成後請自行保存,因為在公眾平臺每次生成查看都會導致 AppSecret 被重置。註意調用所有微信介面時均需使用 https 協議。如果第三方不使用中控伺服器,而是選擇各個業務邏輯點各自去刷新 access_token,那麼就可能會產生衝突,導致服務不穩定。

 

 

 

2.3.2 發送模板消息

 

可以看到發送模板消息,需要首先獲取用戶的openid。

2.4 openid的獲取

下麵轉到openid的獲取

網上都說openid可以調用wx.login函數獲取到code之後獲取openid。下麵網址是wx.login獲取openid的官方介紹。

https://mp.weixin.qq.com/debug/wxadoc/dev/api/api-login.html#wxloginobject

如下圖所示,利用介面地址獲取到openid。

 

 

將上述地址利用wx.request訪問時,在小程式中會報錯,api.weixin.qq.com不在合法功能變數名稱範圍內等。在之前貌似可以直接通過在小程式後端添加合法功能變數名稱就可以解決,如下圖所示。網上教程大都這樣解釋。但是現在api.weixin.qq.com並添不進去。

 

 

但是大多數人都沒有註意後面官方給出的登錄時序圖,從下圖可以看出,上述介面地址是要通過第三方伺服器訪問微信伺服器才能獲得openid的。在小程式中不能直接訪問,所以這就限制了沒有伺服器的開發者,比如我。那麼怎麼辦呢,

 

 

 

三、模板消息解決辦法

在這裡可以選用Bmob的後端雲伺服器。

下麵是Bmob的官方教程

https://docs.bmob.cn/data/wechatApp/b_developdoc/doc/index.html#小程式模板消息

 

 

要將上圖中前四部規規矩矩的配置好,並試驗添加一行數據可否正常運行已檢驗Bmob與小程式配置正常。

 

話不多說 上代碼

 

Wxml文件代碼:

 

<form bindsubmit="formSubmit" report-submit='true'> //主要是這行代碼要有

 

  <!-- <button form-type='submit'>submit</button> -->

    <view class="weui-dialog__btn weui-dialog__btn_default" bindtap="noneWindows">取消</view>

    <button loading="{{loading}}" class="weui-dialog__btn weui-dialog__btn_primary" formType="submit">提交</button>  //然後在有個按鈕就行了

  </view>

</form>

 <button type='primary' bindtap='zhuce'>註冊</button>   //用來獲取openid的按鈕,openid的內容後續會講解

 

Js代碼:

 

var Bmob = require("../utils/bmob.js");

var common = require("../utils/common.js");//配置按照教程來

Bmob.initialize("這兩個字元串教程裡面有 要保證是自己的 不能複製別人的", "");

 

var openid;//儲存openid

 

zhuce:function(){

    wx.login({

      success:function(res){

        if (res.code) {

          //發起網路請求

          console.log(res.code)

 

          Bmob.User.requestOpenId(res.code, {

            success: function (result) {

              that.setData({

                loading: true,

                url: result.openid

              })

              console.log(result.openid)

              openid = result.openid

            },

            error: function (error) {

              // Show the error message somewhere

              console.log("Error: " + error.code + " " + error.message);

            }

          });

        } else {

          console.log('獲取用戶登錄態失敗!' + res.errMsg)

          common.showTip('獲取用戶登錄態失敗!', 'loading');

        }

      }

    })

  }

 

 

 

formSubmit: function (e) {

    var that = this

console.log(e.detail.formId)

 

    var temp = {

      "touser": openid, //

      "template_id": "參數template_id為在微信公眾號獲取到的模板Id",

      "page": "",//跳轉界面 不填就沒有跳轉

      "form_id": e.detail.formId,

      "data": {

        "first": {

          "value": "您好,Restful 失效,請登錄控制台查看。",

          "color": "#c00"

        },

        "keyword1": {

          "value": "339208499",

          "color": "#173177"

        },

        "keyword2": {

          "value": "339208499",

          "color": "#173177"

        },

        "keyword3": {

          "value": "339208499",

          "color": "#173177"

        },

        "remark": {

          "value": "如果您十分鐘內再次收到此信息,請及時處理。"

        }

      },

      "emphasis_keyword": ""

    }

    console.log(temp)

    Bmob.sendMessage(temp).then(function (obj) {

      console.log('發送成功')

    },

      function (err) {

        common.showTip('失敗' + err)

        console.log(err)

      });

  },

 

為什麼能解決問題呢,主要是bmob伺服器幫你把你伺服器上的事完成了,bomb向微信伺服器請求openid。

 註意要用手機調試運行。開發工具的模擬器獲取到的formId是個模擬值。下麵是我的運行情況

 

 

 

 

上述內容可能寫的不夠詳盡,內容繁多,多多少少有些疏漏,若存在問題請在評論區評論,或者私戳我[email protected]

 

技術不易,酌情打賞

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、事務隔離級別控制著事務的如下表現: 在該行上的排他鎖被釋放之前阻塞其他事務。 檢索在啟動語句或事務時存在的行的已提交版本。 讀取未提交的數據修改。 在該行上的排他鎖被釋放之前阻塞其他事務。 檢索在啟動語句或事務時存在的行的已提交版本。 讀取未提交的數據修改。 以上說明事務隔離級別主要針對讀操作來 ...
  • --創建存儲過程create procedure proc_stu@sname varchar(20),@pwd varchar(50),@flag bit outputasif exists(select * from dt_manager m where m.user_name=@sname a ...
  • 17 Group Replication 17 Group Replication.. 1 17.1 Group Replication後臺... 1 17.1.1 Replication技術... 1 17.1.1.1 主從複製... 1 17.1.1.2 Group Replication.. ...
  • 我先說一下我安裝mysql的操作吧: 1、開始的時候,安裝mysql,是那種解壓縮就能用的軟體包。我把它解壓後,拷貝到/usr/local/ 目錄下,並把名字命名為mysql。 2、建立用戶mysql。[root@localhost ~]# useradd mysql 3、修改許可權。[root@lo ...
  • 1.登錄 之後輸入密碼進行登陸 2.許可權設置及說明 2.1添加遠程ip訪問許可權 2.2命令解釋 第一行中,192.168.199.99是阿裡雲內網的一個地址,這個是允許遠程訪問的IP的值。自行改為其他值。 root是賬戶名,後面的FEFJay是密碼。 即,允許來自192.168.199.99的連接並 ...
  • 在使用MongoDB資料庫的過程中,避免不了需要將數據進行導入和導出的工作,下麵為具體的用法。註意 不同的資料庫版本可能存在略微的差異,所以在使用時,先查看 --help 來進行確認。下麵的為3.6版本。Export示例:mongoexport --db test --collection traf... ...
  • 一、準備工作: CentOS鏡像:http://mirrors.163.com/centos/7/isos/x86_64/CentOS-7-x86_64-DVD-1708.iso 二、用VMware搭建虛擬機集群 1.規劃 master:1核、4G記憶體 slave1:1核、2G記憶體 slave2:1 ...
  • 一些列表經常需要編輯多選的功能,而UITableview自帶多選刪除的功能,使用起來方便,不需要自己去做數據存儲和選中狀態轉換,可以減少不少開發時間。下麵就來介紹下UITableView多選的使用。 效果 : UITableViewCellEditingStyle 編輯狀態UITableViewCe ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...