java實現 微信公眾號推送消息 ,cv 就可運行!!!

来源:https://www.cnblogs.com/blbl-blog/archive/2023/10/07/17746168.html
-Advertisement-
Play Games

一,註冊公眾號 1,官網地址:申請測試公眾號 地址: 微信公眾平臺 (qq.com) 文檔地址:微信開放文檔 (qq.com) 2,註冊後可以查看自己的appId 和 appsecret 3,創建模板 請註意: 1、測試模板的模板ID僅用於測試,不能用來給正式帳號發送模板消息 2、為方便測試,測試模 ...


一,註冊公眾號

1,官網地址:申請測試公眾號

地址: 微信公眾平臺 (qq.com)

文檔地址:微信開放文檔 (qq.com)

2,註冊後可以查看自己的appId 和 appsecret

3,創建模板

  • 請註意:
  • 1、測試模板的模板ID僅用於測試,不能用來給正式帳號發送模板消息
  • 2、為方便測試,測試模板可任意指定內容,但實際上正式帳號的模板消息,只能從模板庫中獲得
  • 3、需為正式帳號申請新增符合要求的模板,需使用正式號登錄公眾平臺,按指引申請
  • 4、模板內容可設置參數(模板標題不可),供介面調用時使用,參數需以{{開頭,以.DATA}}結尾

我創建的模板

早安!:{{name.DATA}} 
天氣:{{weather.DATA}} 
距離破殼日:{{birthday.DATA}}

二,代碼部分

​ 發送消息和推送消息都是需要 token 的,所以第一步就可以獲取token,再拿獲取的token 進行發送消息,每天獲取token的是有次數限制的(2000次)

添加依賴

使用微信公眾號需要的依賴

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

我這裡把 也添上,等下可以在swagger測試

        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>

<!--        knife4j 依賴-->
        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>knife4j-spring-boot-starter</artifactId>
            <version>2.0.7</version>
        </dependency>

具體代碼

controller 層

這裡就兩個部分,getToken() 方法 是獲取token, pushMessage() 是推送消息(這裡代碼中沒有模板id,需要修改成上面自己創建的模板id)

@Api(tags = "各項測試")
@RestController
@RequestMapping("/loginInfo")
public class SendWeChatMessageController {

//    /*
//     * 功能: 公眾號:appid,這裡也可以配置到yaml 文件裡面
//     */
//
//    @Value("${wx.appId}")
//    private String appId;
//
//    /*
//     * 功能: 公眾號:appsecret
//     */
//
//    @Value("${wx.appsecret}")
//    private String appsecret;
    private final Logger logger = LoggerFactory.getLogger(SendWeChatMessageController.class);




    @ApiOperation("獲取token")
    @GetMapping("/getToken")
    public Object getToken(@PathParam("grantType") String grantType,@PathParam("appId") String appId,@PathParam("secret") String secret) throws Exception {
        String tokenUrl = WeChatUrlEnum.TOKEN.getUrl();
        String params = "grant_type=" + grantType + "&appid=" + appId + "&secret=" + secret;
        logger.info("請求地址為:" + tokenUrl + params);
        String tokenResponse = HttpUtils.sendGet(tokenUrl, params);
        JSON parse = JSONUtil.parseObj(tokenResponse);
        System.out.println(parse);
        return parse;
    }


    @ApiOperation("發送消息")
    @PostMapping("/testPushMessage")
    public String pushMessage(@RequestBody PushMessageToUserVo pushMessageToUserVo) {
        // 組裝要發送的數據
        JSONObject body = new JSONObject();
        // 要推給誰
        body.put("touser", pushMessageToUserVo.getTouser());
        // 模板ID
        body.put("template_id", "這裡填寫自己的模板id");

        String accessToken = pushMessageToUserVo.getAccessToken();

        // 創建消息和內容,這裡可以自己定義,對應好模板就行
        JSONObject data = new JSONObject();
        data.put("name", new JSONObject().put("value", "做一個身體和心靈都勇敢的人,趁著身體未老,心靈還透明。晚安!"));
        data.put("weather", new JSONObject().put("value", "陰天  19°c"));
        data.put("birthday", new JSONObject().put("value", "53   天"));
        body.put("data", data);

        logger.info("body---->{}", body.toString());

        String post = HttpUtil.post("https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken, body.toString());
        logger.info("通知到用戶--->{}", post);
        return body.toString();
    }
}

其他代碼

config

這裡使用 knife4j,等下好測試介面

@Configuration
@EnableSwagger2
public class SwaggerConfiguration {

    @Bean(value = "defaultApi2")
    public Docket defaultApi2() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(new ApiInfoBuilder()
                        //.title("swagger-bootstrap-ui-demo RESTful APIs")
                        .description("# swagger-bootstrap-ui-demo RESTful APIs")
                        .termsOfServiceUrl("http://www.xx.com/")
                        .contact("[email protected]")
                        .version("1.0")
                        .build())
                //分組名稱
                .groupName("2.X版本")
                .select()
                //這裡指定Controller掃描包路徑,自行記得修改!!!!
                .apis(RequestHandlerSelectors.basePackage("com.example.springbootwechat.controller"))
                .paths(PathSelectors.any())
                .build();
    }
}

entity

這個是推送消息vo,給那個用戶推送消息,並帶上token

@Data
@ApiModel(description = "用戶推送vo")
public class PushMessageToUserVo {

    @ApiModelProperty(value = "用戶微信關註號", required = true)
    private String touser;

    @ApiModelProperty(value = "用戶Token", required = true)
    private String accessToken;

}

enum

我這裡是把地址都變成枚舉,因為後面地址會比較多,便於維護,當然也可以配置在yaml ,或者定義在使用處。

public enum WeChatUrlEnum {

    /**
     * 獲取token
     */
    TOKEN("獲取微信 token的地址","https://api.weixin.qq.com/cgi-bin/token");

    private String info;
    private String url;

    WeChatUrlEnum(String info,String url) {
        this.info =info;
        this.url = url;
    }

    public String getInfo() {
        return info;
    }

    public void setInfo(String info) {
        this.info = info;
    }

    public String getUrl() {
        return url;
    }

    public void setUrl(String url) {
        this.url = url;
    }
}

utils

工具類:發送http get,post 請求

public class HttpUtils {

   public static String sendGet(String url, String query) throws Exception {
       String fullUrl = url + "?" + query;
       HttpURLConnection connection = (HttpURLConnection) new URL(fullUrl).openConnection();
       connection.setRequestMethod("GET");
       connection.setRequestProperty("Accept", "application/json");

       if (connection.getResponseCode()!= 200) {
           throw new RuntimeException("Failed : HTTP error code : " + connection.getResponseCode());
       }

       BufferedReader br = new BufferedReader(new InputStreamReader((connection.getInputStream())));

       StringBuilder sb = new StringBuilder();
       String output;
       while ((output = br.readLine())!= null) {
           sb.append(output);
       }
       connection.disconnect();
       return sb.toString();
   }


   public static String sendPost(String url, String data) throws Exception {
       URL fullUrl = new URL(url);
       HttpURLConnection connection = (HttpURLConnection) fullUrl.openConnection();
       connection.setRequestMethod("POST");
       connection.setRequestProperty("Content-Type", "application/json");
       connection.setRequestProperty("Accept", "application/json");

       connection.setDoOutput(true);
       DataOutputStream wr = new DataOutputStream(connection.getOutputStream());
       wr.writeBytes(data);
       wr.flush();
       wr.close();

       if (connection.getResponseCode()!= 200) {
           throw new RuntimeException("Failed : HTTP error code : " + connection.getResponseCode());
       }

       BufferedReader br = new BufferedReader(new InputStreamReader((connection.getInputStream())));

       StringBuilder sb = new StringBuilder();
       String output;
       while ((output = br.readLine())!= null) {
           sb.append(output);
       }

       connection.disconnect();

       return sb.toString();
   }
}

測試

介面swagger地址:http://127.0.0.1:1955/doc.html 自己註意埠

1,獲取token

2,發送消息

手機端:接收到的消息

謝謝看到這!!!有不對地方,可以留言評論討論哦!!!

希望可以動動小手,點個關註!!!


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

-Advertisement-
Play Games
更多相關文章
  • 環境分類,可以分為 本地環境、測試環境、生產環境等,通過對不同環境配置內容,來實現對不同環境做不同的事情。 AntDesign 項目,通過 config.xxx.ts 添加不同的尾碼來區分配置文件,啟動時候通過尾碼啟動即可。 config.ts : 公共配置 config.xxx.ts:不同環境的差 ...
  • 更新元組 更改元組的值 元組是不可更改的,但有一種變通方法。您可以將元組轉換為列表,更改列表,然後將列表轉換回元組。 示例: x = ("apple", "banana", "cherry") y = list(x) y[1] = "kiwi" x = tuple(y) print(x) 添加項 由 ...
  • #include <graphics.h> #include <iostream> #include <Windows.h> #include <string> #include <conio.h> using namespace std; #define LINE 9 //行數 #define C ...
  • 一、介紹 01.Go 語言的前生今世 二、開發環境搭建 01.Go 語言開發環境搭建 三、初識GO語言 01.Go 多版本管理工具 02.第一個 Go 程式“hello,world“ 與 main 函數 03.Go 常用命令介紹 04.Go 項目代碼佈局 05.探索 GO 項目依賴包管理與Go Mo ...
  • 基於java校園課程作業管理系統設計與實現,可適用於班級管理、學生管理、教師管理、課程管理、課程信息管理、學生選課管理、作業佈置管理、作業提交管理、作業評分管理、課程評價管理、課程資源管理,作業管理系統,大學提交作業,佈置作業管理系統,學校作業管理系統等等 ...
  • Python是一種廣泛使用的編程語言,可以輕鬆地幫助我們完成許多任務。Python可以用於網路開發和軟體開發。 在這篇文章中,我們將研究如何在Python中創建一個包。包是一個可重覆使用的代碼文件,我們可以通過從包中導入主文件並使用這些文件中定義的其餘函數和定義來實現多種目的。 讓我們創建一個帶有一 ...
  • 如上所述,我們可以使用Python庫做各種事情,如創建虛擬環境、單元測試、創建數獨解算器等。我們可以用Python做的另一個簡單活動是生成隨機數。 有時在編碼時,我們可能需要不同位數的隨機數。我們可以把它用於密碼、設備的安全引腳等。 使用random 模塊在Python中生成隨機數 為了實現這些目標 ...
  • 在知乎看到一個這樣的問題:“為什麼別選電腦專業?” 來源:https://www.zhihu.com/question/465369002/answer/2213759239 這個話題有756人關註,以及1,721,580人次瀏覽。以下是一位匿名用戶的高贊回答,內容可能比較主觀化,僅代表作者個人觀 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...