您好,登錄后才能下訂單哦!
小編給大家分享一下微信開發(fā)之怎么成為開發(fā)者,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
1. 微信公眾號的三種類型
到網(wǎng)址: https://mp.weixin.qq.com 注冊微信號時,要求我們在目前微信公眾號的三種類型(訂閱號、服務(wù)號、企業(yè)號)中進行選中,他們的區(qū)別如下所示:
使用得多的公眾號是訂閱號和服務(wù)號,企業(yè)號一般是同一個公司的員工交流協(xié)作使用的,企業(yè)號對外是不公開的,不可訪問的,只有企業(yè)的員工可以訪問;訂閱號和服務(wù)號是對外公開的,任何人可以關(guān)注。而訂閱號一般用于向關(guān)注者定期推送一些圖文信息,也可以提供一些其他的查詢類的服務(wù),而服務(wù)號具有微信支付功能,所以一般用于商業(yè)用途。比如微商城,微拍賣等等。
2.開啟微信開發(fā)者功能
在申請了微信公眾號之后,如果需要在微信平臺進行開發(fā),則必須先要開啟微信開發(fā)者功能。開啟微信開發(fā)者功能,要寫驗證代碼,而且必須要有可以訪問的網(wǎng)址。首先登錄微信公眾平臺:https://mp.weixin.qq.com/
點擊“開發(fā)者中心”,勾上“我同意”,點擊“成為開發(fā)者”:
來到下面的頁面:
點擊“配置項”,其中有URL和Token要我們填寫,URL是指開啟開發(fā)者功能時,微信服務(wù)端會向該URL的地址發(fā)送一個get請求,get請求的參數(shù)有:
1)時間戳:timestamp
2)隨機數(shù):nonce
3)隨機字符串:echostr
4)以及上面三個參數(shù)的值以字典順序組成的字符串的 SHA-1 算法的摘要信息:signature
我們要完成的是:在填寫的URL的get請求處理類中獲得timestamp,nonce,echostr,signature四個參數(shù),然后以同樣的方式,對timestamp,nonce,token一字典順序組成的字符串計算它們的 SHA-1 算法的摘要信息 signature2,然后比較signature2 和 signature的值是否一樣,如果一樣的話就原樣返回 echostr,微信服務(wù)器收到 echostr ,則開發(fā)者功能開啟成功。注意這里的token就是上面要填寫的Token.
注:如果你做過支付寶的接入,那么會發(fā)現(xiàn)這里的校驗和支付寶的校驗有個小小的區(qū)別,支付寶校驗的字符串是按照參數(shù)和參數(shù)的值組成的鍵值對中的key的字典順序排序的,并且字符串的組成是:key1=value1+ & + key2=value2;而微信參與校驗的字符串為:value1 + value2 + ... 沒有包括key,并且是按照value的字段順序排序的。
相應(yīng)的java代碼如下:
處理微信get請求的servlet:
/** * 微信請求處理的核心類 */ public class CoreServlet extends HttpServlet { private static final long serialVersionUID = 4440739483644821986L; /** * 請求校驗(確認請求來自微信服務(wù)器) */ public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 微信服務(wù)端發(fā)來的加密簽名 String signature = request.getParameter("signature"); // 時間戳 String timestamp = request.getParameter("timestamp"); // 隨機數(shù) String nonce = request.getParameter("nonce"); // 隨機字符串 String echostr = request.getParameter("echostr"); PrintWriter out = response.getWriter(); // 請求校驗,若校驗成功則原樣返回echostr,表示接入成功,否則接入失敗 if (SignUtil.checkSignature(signature, timestamp, nonce)) { out.print(echostr); } out.close(); }
請求校驗工具類:
package com.sinaapp.wx.util; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Arrays; import com.sinaapp.wx.config.ParameterConfig; /** * 請求校驗工具類 */ public class SignUtil { /** * 校驗簽名 * * @param signature 微信加密簽名 * @param timestamp 時間 * @param nonce 隨機字符串 * @return */ public static boolean checkSignature(String signature, String timestamp, String nonce) { String token = ParameterConfig.WX_TOKEN; String[] paramArr = new String[] { token, timestamp, nonce }; Arrays.sort(paramArr); // 對token、timestamp和nonce按字典排序 // 將排序后的結(jié)果拼接成字符串 StringBuilder sb = new StringBuilder(paramArr[0]); sb.append(paramArr[1]); sb.append(paramArr[2]); String cipherText = null; try { MessageDigest md = MessageDigest.getInstance("SHA-1"); byte[] digest = md.digest(sb.toString().getBytes()); // 對接后的字符串進行sha1加密 cipherText = byteToStr(digest); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } // 將加密后的字符串與微信服務(wù)器發(fā)來的簽名signature進行對比 return cipherText != null ? cipherText.equals(signature.toUpperCase()) : false; } /** * 將字節(jié)數(shù)組轉(zhuǎn)換為十六進制字符 * * @param byteArray * @return */ private static String byteToStr(byte[] byteArray) { String strDigest = ""; for (int i = 0; i < byteArray.length; i++) { strDigest += byteToHexStr(byteArray[i]); } return strDigest; } /** * 將單個字節(jié)轉(zhuǎn)換為十六進制字符 * * @param mByte * @return */ private static String byteToHexStr(byte mByte) { char[] Digit = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' }; char[] tempArr = new char[2]; tempArr[0] = Digit[(mByte >>> 4) & 0X0F]; // 取一個字節(jié)的高4位,然后獲得其對應(yīng)的十六進制字符 tempArr[1] = Digit[mByte & 0X0F]; // 取一個字節(jié)的低4位,然后獲得其對應(yīng)的十六進制字符 return new String(tempArr); } }
代碼中String token = ParameterConfig.WX_TOKEN的值必須和上面填寫的Token一致。在web.xml中配置該servlet:
<servlet> <servlet-name>coreServlet</servlet-name> <servlet-class>com.sinaapp.wx.servlet.CoreServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>coreServlet</servlet-name> <url-pattern>/coreServlet</url-pattern> </servlet-mapping>
然后放入公網(wǎng)可以訪問的網(wǎng)址下面,然后將該servlet的訪問地址填入上面的URL中。然后點擊“提交”按鈕,如果一切成功就會有下面的提示信息:
到這里我們成功的開啟了微信的開發(fā)者功能,可以進行微信的開發(fā)了。我們獲得了AppID, AppSecret,這兩個在微信支付中都要使用到。
注:
微信的開發(fā)文檔地址為:http://mp.weixin.qq.com/wiki/home/index.html
開啟微信開發(fā)者的文檔如下:
以上是“微信開發(fā)之怎么成為開發(fā)者”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。