一、申請測試公衆號
用自己的微信掃一掃就可以申請,各個接口權限也都是開着的。
二、在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等基礎配置。
打開這個文件,然後把微信接口測試裏面的
把上面那張圖的authtoken複製後填入這裏的authtoken的等號後面。
4、雙擊運行natapp.exe
這個時候就能看到這樣的界面了
這就說明你的本機ip地址+端口號已經映射成了紅色框框裏面的地址,這是一個外網地址。
用這個網址放到瀏覽器網址裏,嘗試鏈接一個你本機的端口號爲8080的項目,看看能不能成功,如果運行完界面與之前的是一樣的,就說明內網穿透成功了。
把這個地址複製下來,然後後面加上上面那個controller的接口,變成:http://wh5gh6.natappfree.cc/wxdemo,把這個地址放置到微信接口測試頁面的URL裏,把上面controller裏面的token:“good”,也填到下面的token框裏面(這個token可以隨意填寫,但是要和後臺一致)
把後臺springboot項目打開,然後點擊提交按鈕,出現配置成功的字樣就可以了。
然後去掉url裏面的http://,把剩下的信息填入到下面的js接口域名中就可以了。
嗯,親測好用。
如果有什麼問題可以在底下評論,大家一起探討。
感謝原博主,當時解決了我的問題。