首頁 > 軟體

微信公眾號服務號推播模板訊息設定方法(後端java)

2023-02-24 06:02:37

模板訊息檔案

公眾號的型別分為服務號、訂閱號和企業號,其中服務號和訂閱號比較常見。要想實現公眾號推動訊息給指定的使用者,其型別必須為服務號。

推播的模板訊息範例如下 :

設定模板訊息

此處為正式環境的設定,開發環境可使用微信測試平臺提供的測試賬號體驗和測試公眾平臺的所有高階介面,無需提前申請稽核,詳情見本文最後章節。

首次設定需要開啟模板訊息功能,登入公眾號後臺: mp.weixin.qq.com ,在左側導航欄最下方有「新增新的功能」,開啟,在「廣告與服務」一類中找到「模板訊息」,開通即可。

開啟「模板訊息」,選擇模板庫,需先選擇所在行業(一個月只能修改一次),之後在下方的行業模板中選擇合適的模板(可以搜尋模板關鍵字)。

新增完選擇的模板後在「我的模板」中可以檢視模板的詳細資訊,此處的模板ID後面程式碼中會用到。

編碼

1. 新增依賴

// Gradle
dependencies {
	// ...
	compile "com.github.binarywang:weixin-java-mp:3.3.0"
	// ...
}


// Maven
<dependency>
  <groupId>com.github.binarywang</groupId>
  <artifactId>weixin-java-mp</artifactId>
  <version>3.0.0</version>
</dependency>

2. SubscriptionMessageUtil.java

import me.chanjar.weixin.mp.api.WxMpInMemoryConfigStorage;
import me.chanjar.weixin.mp.api.WxMpService;
import me.chanjar.weixin.mp.api.impl.WxMpServiceImpl;
import me.chanjar.weixin.mp.bean.template.WxMpTemplateData;
import me.chanjar.weixin.mp.bean.template.WxMpTemplateMessage;

import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Date;
import java.util.List;

public class SubscriptionMessageUtil {

    /**
     * 下單後通知供貨商
     */
    public static void sendOrderMsg(String appid,
                                    String appSecret,
                                    String userOpenid,
                                    String orderId,
                                    String serviceName) {

        // 模板訊息 ID
        // {{first.DATA}}
        // 訂單編號:{{keyword1.DATA}}
        // 訂貨終端:{{keyword2.DATA}}
        // 下單時間:{{keyword3.DATA}}
        // {{remark.DATA}}
        String OrderMsgTemplateId = "Th5MwuyqSjfADUDOJ5PSGDf1swr1-nHmOtLYlVX8n_8";

        // 卡片詳情跳轉頁,設定此值,當點選訊息時會開啟指定的頁面
//        String detailUrl = "https://bing.com";

        SimpleDateFormat sdf = new SimpleDateFormat();
        sdf.applyPattern("yyyy-MM-dd HH:mm");
        Date date = new Date();
        String timeNow = sdf.format(date);

        WxMpInMemoryConfigStorage wxStorage = new WxMpInMemoryConfigStorage();
        wxStorage.setAppId(appid);
        wxStorage.setSecret(appSecret);

        WxMpService wxMpService = new WxMpServiceImpl();
        wxMpService.setWxMpConfigStorage(wxStorage);

      	// 此處的 key/value 需和模板訊息對應
        List<WxMpTemplateData> wxMpTemplateDataList = Arrays.asList(
                new WxMpTemplateData("first", "您有一個新的訂貨單", "#000000"),
                new WxMpTemplateData("keyword1", orderId),
                new WxMpTemplateData("keyword2", serviceName),
                new WxMpTemplateData("keyword3", timeNow),
                new WxMpTemplateData("remark", "請登入系統檢視訂單詳情並及時配貨")
        );

        WxMpTemplateMessage templateMessage = WxMpTemplateMessage.builder()
                .toUser(userOpenid)
                .templateId(OrderMsgTemplateId)
                .data(wxMpTemplateDataList)
//                .url(detailUrl)
                .build();

        try {
            wxMpService.getTemplateMsgService().sendTemplateMsg(templateMessage);
        } catch (Exception e) {
            System.out.println("推播失敗:" + e.getMessage());
        }

    }

}

3. 設定引數

xx.properties

wx:
  mp:
    appid: xxx
    appSecret: xxx

4. 使用

在需要的 Controller 中直接參照即可

@Controller
@RequestMapping("/order")
public class XXController {
  
	@Value("${wx.mp.appid}")
	private String APPID;

	@Value("${wx.mp.appSecret}")
	private String APP_SECRET;
  
  @RequestMapping(value = "/create", method = RequestMethod.POST)
  public CommonResult create() {
    
    String openid = "";		// 傳送給指定的使用者
    String serviceName = "";
    String orderNo = "";
    
    SubscriptionMessage.sendOrderMsg(APPID, APP_SECRET, openid, orderNo, serviceName);
  }
  
}

微信測試號

開發過程中直接使用正式微訊號、公眾號可能會有諸多不便,所以微信公眾平臺提供介面測試賬號,可直接體驗和測試公眾平臺所有高階介面。

地址: 微信公眾平臺測試賬號

登入後可檢視測試賬號的 appid、appsecret

可以使用微信掃描頁面下方的測試公眾號二維條碼關注,關注後可獲取當前微訊號的測試 openid(非公眾賬號的 openid),可用於程式碼中臨時指定模板訊息接收使用者,方便開發。

該測試平臺還提供測試用模板訊息,可自定義模板訊息,建立完成後會臨時生成模板 ID ,程式碼中直接替換即可。

接收訊息範例如下:

總結 

到此這篇關於微信公眾號服務號推播模板訊息設定方法的文章就介紹到這了,更多相關公眾號推播模板訊息內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章,希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com