一、初始微信公眾平臺
微信公眾平臺,即我們平時所說的“公眾號”,曾用名“官方平臺”、“媒體平臺”,但最終命名為“公眾平臺”。從微信的命名我可以發(fā)現(xiàn),公眾平臺不只是官方、媒體使用的平臺,而是對所有公眾都開放的統(tǒng)一平臺。
喜歡本文,請點(diǎn)擊下方喜歡按鈕唄!??
微信公眾平臺地址:https://mp.weixin.qq.com/
微信公眾平臺公分4大板塊:訂閱號、服務(wù)號、小程序、企業(yè)號。按照微信2016年公開課規(guī)劃,企業(yè)號后續(xù)將與企業(yè)微信合并,因此我們主要針對前三部分開始講解:
簡單的對比一下前三者的區(qū)別以及本次課程即后續(xù)課程的講解重點(diǎn):
1、訂閱號和服務(wù)號均為傳統(tǒng)意義的“公眾號”,具有消息群發(fā)能力,詳細(xì)區(qū)別可在官方平臺查看:http://kf.qq.com/faq/140806zARbmm140826M36RJF.html我們將注重于服務(wù)能力開發(fā),而在服務(wù)方面,兩者開發(fā)模式完全相同,只不過服務(wù)號可以使用更多的服務(wù)接口,而訂閱號則是“閹割版”的服務(wù)號。因此,后續(xù)課程我們將使用服務(wù)號為案例進(jìn)行操作。
2、微信小程序,原本為“微信應(yīng)用號”,即一個根植在微信生態(tài)系統(tǒng)內(nèi)的APP。因蘋果和谷歌的限制,“應(yīng)用號”未上線便已夭折,取而代之的是適度閹割功能的“微信小程序”,而其堪比原生APP的操作體驗(yàn),也使得小程序成為時下大火的開發(fā)方向。而杰瑞教育全新的H5開發(fā)課程,也將加入時下火爆的微信小程序開發(fā)。
二、開發(fā)賬號準(zhǔn)備
1、賬號注冊
進(jìn)入微信公眾平臺https://mp.weixin.qq.com,點(diǎn)擊右上角立即注冊,選擇“服務(wù)號”或“訂閱號”注冊(服務(wù)號僅限機(jī)構(gòu)用戶注冊,個人用戶只能選擇訂閱號)
注冊時需填寫一系列信息,根據(jù)提示填寫即可,此處不做贅述。
2、測試賬號申請
如果暫時不想注冊賬號,或者無法注冊服務(wù)號,可選擇官方提供的測試賬號申請。申請地址:http://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login點(diǎn)擊后掃描二維碼,即可獲得一個測試賬號,擁有服務(wù)號全部權(quán)限。
三、開發(fā)環(huán)境準(zhǔn)備
1、外網(wǎng)映射工具
微信公眾平臺在訪問后臺時,必須提供能夠正確訪問的外網(wǎng)地址,微信平臺對后臺URL的要求有兩點(diǎn):
①必須能夠用公網(wǎng)訪問②必須使用80端口
要實(shí)現(xiàn)以上兩點(diǎn),我們可以選擇購買外網(wǎng)服務(wù)器,例如:阿里云、百度云、騰訊云…都是不錯的選擇。如果沒有服務(wù)器,可以選擇用外網(wǎng)映射工具,將我們的內(nèi)網(wǎng)鏈接映射為公網(wǎng),比較不錯的映射軟件有:花生殼、ngrok、nat123等…
這幾款軟件都可以百度很容易搜索到并下載,下面簡單講解一下用法:
① Ngrock:
進(jìn)入dos環(huán)境,切換到ngrock所在盤符,輸入ngrock8080回車:
回車后等待一會,即可得到公網(wǎng)鏈接,下圖所示陰影區(qū)域給出的鏈接,即可直接訪問本機(jī)127.0.0.1:8080下的鏈接內(nèi)容,分別是http協(xié)議和https協(xié)議對應(yīng)的地址:
②花生殼、nat123,均可安裝軟件后,在軟件中操作,詳情可查看百度經(jīng)驗(yàn):http://jingyan.baidu.com/article/363872ec361d3f6e4ba16ff9.html此處不做贅述
四、微信公眾平臺數(shù)據(jù)交互原理
搭建好公網(wǎng)訪問地址后,我們自己開發(fā)的后臺代碼就可以放到公網(wǎng)地址了,那么用戶是怎么樣訪問到我們的代碼呢?
下面我們來看一下微信公眾平臺的數(shù)據(jù)交互原理:
從上圖可以看到,微信公眾平臺實(shí)際只是起到一個橋梁作用,實(shí)際處理業(yè)務(wù)、提供服務(wù)的代碼,依然是放在我們自己的服務(wù)器或者公網(wǎng)映射上面。
那么,我們就可以在我們自己的電腦(服務(wù)器)上面編寫后臺代碼,并通過映射工具提供公網(wǎng)能夠訪問的URL,然后將此URL綁定到微信后臺即可。
五、開發(fā)模式接入
下面將進(jìn)入實(shí)際開發(fā)過程,我們可以參考官方提供的開發(fā)文檔:https://mp.weixin.qq.com/wiki
1、填寫服務(wù)器配置
進(jìn)入微信公眾平臺,點(diǎn)擊左側(cè)【開發(fā)——基本配置】,選擇【服務(wù)器配置】。即可進(jìn)入配置頁面:
其中:
URL:即我們上述所說的后臺服務(wù)器公網(wǎng)訪問地址
Token:開發(fā)者自定的驗(yàn)證口令
EncodingAESKey:隨機(jī)字符串,如果消息加解密方式采用安全模式才需驗(yàn)證
2、驗(yàn)證消息是否有效
當(dāng)我們點(diǎn)擊提交時,微信服務(wù)器將會發(fā)送一個Get請求,到我們上述地址,同時傳遞四個參數(shù):
我們通過檢驗(yàn)signature對請求進(jìn)行校驗(yàn)(下面有校驗(yàn)方式)。若確認(rèn)此次GET請求來自微信服務(wù)器,請?jiān)瓨臃祷豦chostr參數(shù)內(nèi)容,則接入生效,成為開發(fā)者成功,否則接入失敗。加密/校驗(yàn)流程如下:
下面,我們實(shí)現(xiàn)代碼操作。
六、開發(fā)接入后臺代碼
1、使用MyEclipse創(chuàng)建Web項(xiàng)目,并新建一個servlet:
2、在servlet的doGet方法中,獲取上述四個校驗(yàn)參數(shù):
3、編寫工具類,進(jìn)行校驗(yàn)方法的操作:
校驗(yàn)步驟,參考上述【五-2】三大步操作流程
使用sha1加密方法↓
4、 Servlet中調(diào)用校驗(yàn)方法,并驗(yàn)證結(jié)果,如果檢驗(yàn)成功,將得到的隨機(jī)字符串eahostr原路返回結(jié)果給微信平臺:
至此,Servlet及Check工具類,編寫完成。
5、啟動Tomcat,將Servlet的本地地址(例如本機(jī)為:localhost:8080/WeiXin/servlet/WeiXinServlet)進(jìn)行公網(wǎng)映射,參照上述第三大部分內(nèi)容,進(jìn)行公網(wǎng)映射,確定公網(wǎng)地址能夠正確訪問。
我將直接將將代碼放到公網(wǎng)服務(wù)器進(jìn)行訪問。獲得如下地址:http://www.jredu100.com/WeiXin/servlet/WeiXinServlet
七、配置公眾平臺后臺
進(jìn)入微信后臺配置相關(guān)信息:
點(diǎn)擊提交,微信將發(fā)送Get指令到Servlet,并調(diào)用doGet方法,進(jìn)行我們編寫的驗(yàn)證操作,最后如果順利返回隨機(jī)字符串,則綁定成功。
八、源碼共享
1、 Servlet源碼(只保留doGet部分):
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String signature = request.getParameter("signature");
String timestamp = request.getParameter("timestamp");
String nonce = request.getParameter("nonce");
String echostr = request.getParameter("echostr");
PrintWriter out = response.getWriter();
if(CheckUtil.checkSignature(signature, timestamp, nonce)){
//如果校驗(yàn)成功,將得到的隨機(jī)字符串原路返回
out.print(echostr);
}
}
2、 CheckUtil源碼(可直接Copy其中的getSha1加密方法):
package com.jredu.util;
import java.security.MessageDigest;
import java.util.Arrays;
public class CheckUtil {
public static final String ?tooken = "jredu100"; //開發(fā)者自行定義Tooken
public static boolean checkSignature(String signature,String timestamp,String nonce){
//1.定義數(shù)組存放tooken,timestamp,nonce
String[] arr = {tooken,timestamp,nonce};
//2.對數(shù)組進(jìn)行排序
Arrays.sort(arr);
//3.生成字符串
StringBuffer sb = new StringBuffer();
for(String s : arr){
sb.append(s);
}
//4.sha1加密,網(wǎng)上均有現(xiàn)成代碼
String temp = getSha1(sb.toString());
//5.將加密后的字符串,與微信傳來的加密簽名比較,返回結(jié)果
return temp.equals(signature);
}
public static String getSha1(String str){
if(str==null||str.length()==0){
return null;
}
char hexDigits[] = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
try {
MessageDigest mdTemp = MessageDigest.getInstance("SHA1");
mdTemp.update(str.getBytes("UTF-8"));
byte[] md = mdTemp.digest();
int j = md.length;
char buf[] = new char[j*2];
int k = 0;
for (int i = 0; i < j; i++) {
byte byte0 = md[i];
buf[k++] = hexDigits[byte0 >>> 4 & 0xf];
buf[k++] = hexDigits[byte0 & 0xf];}
char hexDigits[] = {'0','1','2','3','4','5','6','7','8','9',
'a','b','c','d','e','f'};
try {
MessageDigest mdTemp = MessageDigest.getInstance("SHA1");
mdTemp.update(str.getBytes("UTF-8"));
byte[] md = mdTemp.digest();
int j = md.length;
char buf[] = new char[j*2];
int k = 0;
for (int i = 0; i < j; i++) {
byte byte0 = md[i];
buf[k++] = hexDigits[byte0 >>> 4 & 0xf];
buf[k++] = hexDigits[byte0 & 0xf];
}
return new String(buf);
} catch (Exception e) {
// TODO: handle exception
return null;
}
}
}
【版權(quán)聲明】
原創(chuàng)內(nèi)容,歡迎轉(zhuǎn)載!轉(zhuǎn)載請注明出處!需要源碼下載,請聯(lián)系博主!微博@小風(fēng)飛魚