微信開發——基於springboot接入微信公衆號(ngrok內網穿透技術)

一、申請測試公衆號

用自己的微信掃一掃就可以申請,各個接口權限也都是開着的。

二、在spring工程下寫好一個controller

要保證能在你的電腦上成功啓動。
package com.aim.jsr.controller;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;

/**
 * Created by Amy on 2018/1/26.
 */
@RestController
public class WechatController {

    private String TOKEN = "good";

    /**
     * @param signature 微信加密簽名,結合了開發者填寫的token參數和請求中的timestamp參數、nonce參數
     * @param timestamp 時間戳
     * @param nonce 隨機數
     * @param echostr 隨機字符串
     * @return
     */
    @GetMapping("/wxdemo")
    public String test(@RequestParam("signature") String signature,
                       @RequestParam("timestamp") String timestamp,
                       @RequestParam("nonce") String nonce,
                       @RequestParam("echostr") String echostr) {

        //將token、timestamp、nonce三個參數進行字典序排序
        String sortString = sort(TOKEN, timestamp, nonce);
        //將三個參數字符串拼接成一個字符串進行sha1加密
        String myString = sha1(sortString);
        //開發者獲得加密後的字符串可與signature對比,標識該請求來源於微信
        if (myString != null && myString != "" && myString.equals(signature)) {
            System.out.println("簽名校驗通過");
            //如果檢驗成功原樣返回echostr,微信服務器接收到此輸出,纔會確認檢驗完成。
            return echostr;
        } else {
            System.out.println("簽名校驗失敗");
            return "";
        }
    }

    public String sort(String token, String timestamp, String nonce) {
        String[] strArray = {token, timestamp, nonce};
        Arrays.sort(strArray);
        StringBuilder sb = new StringBuilder();
        for (String str : strArray) {
            sb.append(str);
        }

        return sb.toString();
    }

    public String sha1(String str) {
        try {
            MessageDigest digest = MessageDigest.getInstance("SHA-1");
            digest.update(str.getBytes());
            byte messageDigest[] = digest.digest();
            // Create Hex String
            StringBuffer hexString = new StringBuffer();
            // 字節數組轉換爲 十六進制 數
            for (int i = 0; i < messageDigest.length; i++) {
                String shaHex = Integer.toHexString(messageDigest[i] & 0xFF);
                if (shaHex.length() < 2) {
                    hexString.append(0);
                }
                hexString.append(shaHex);
            }
            return hexString.toString();

        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return "";
    }

}
能看到這個controller裏能接收的token爲“good”。

三、接口配置信息

在這裏我們需要一個url和一個token。這個url指的是能夠接收處理微信服務器發送的GET/POST請求的地址,並且是已經存在的,現在就能夠在瀏覽器訪問到的地址,這就要求我們先把公衆帳號後臺處理程序開發好(至少應該完成了對GET請求的處理)並部署在公網服務器上。這裏我用到了natapp來實現內網穿透,將本機ip地址部署到公網服務器上,這個方法是免費的呦( ´∀`),短期內進行測試接口還是可以的,但是缺點是域名會隨機的進行改變,不利於長期進行微信開發。
具體步驟介紹:

1、下載natapp

natapp是基於ngrok的國內高速內網穿透服務商。

2、進入natapp官網,右上角註冊一個natapp賬號

註冊成功後,進入如下界面,購買一個免費隧道


點擊免費購買即可。然後回到首頁,點擊我的隧道

能看到這些信息就算可以了。

3、下載config.ini

使用本地配置文件config.ini,可以將配置保存起來,免去每次運行都輸入authtoken等基礎配置。
下載地址:下載config.ini
打開這個文件,然後把微信接口測試裏面的
把上面那張圖的authtoken複製後填入這裏的authtoken的等號後面。

4、雙擊運行natapp.exe

這個時候就能看到這樣的界面了


這就說明你的本機ip地址+端口號已經映射成了紅色框框裏面的地址,這是一個外網地址。
用這個網址放到瀏覽器網址裏,嘗試鏈接一個你本機的端口號爲8080的項目,看看能不能成功,如果運行完界面與之前的是一樣的,就說明內網穿透成功了。
把這個地址複製下來,然後後面加上上面那個controller的接口,變成:http://wh5gh6.natappfree.cc/wxdemo,把這個地址放置到微信接口測試頁面的URL裏,把上面controller裏面的token:“good”,也填到下面的token框裏面(這個token可以隨意填寫,但是要和後臺一致)
把後臺springboot項目打開,然後點擊提交按鈕,出現配置成功的字樣就可以了。
然後去掉url裏面的http://,把剩下的信息填入到下面的js接口域名中就可以了。


嗯,親測好用。
如果有什麼問題可以在底下評論,大家一起探討。

感謝原博主,當時解決了我的問題。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章