java微信開發(fā)API第三步 微信獲取以及保存接口調(diào)用憑證
微信如何獲取以及保存接口調(diào)用憑證,下面就為大家進行介紹
一、說明
*詳細說明請參考前兩篇文章。
*本文分為三部分:
接口調(diào)用憑證access_token的作用以及解釋
如何獲取接口調(diào)用憑證access_token
如何實現(xiàn)微信文檔所說的“中控服務(wù)器”的實現(xiàn)以保存access_token
* 本文結(jié)束會給出包括本文前三篇文章的所有演示源碼
為什么要獲取和保存接口調(diào)用憑證access_token
•開始開發(fā)-獲取接口調(diào)用憑據(jù)
◦文檔地址:http://mp.weixin.qq.com/wiki/14/9f9c82c1af308e3b14ba9b973f99a8ba.html
•官網(wǎng)文檔給出這樣解釋:
◦access_token是公眾號的全局唯一票據(jù),公眾號調(diào)用各接口時都需使用access_token。開發(fā)者需要進行妥善保存。access_token的存儲至少要保留512個字符空間。access_token的有效期目前為2個小時,需定時刷新,重復獲取將導致上次獲取的access_token失效。
•理解:
◦我們簡單翻閱文檔可以發(fā)現(xiàn),許多高級功能,例如:自定義菜單、素材管理、用戶管理、賬號管理等各種高級功能請求的鏈接中都有“?access_token=TOKEN”這個參數(shù),這是全局調(diào)用參數(shù),微信后臺需要根據(jù)這個參數(shù)確定身份,保證我們的微信公眾號的安全。
◦為了防止公眾號的程序錯誤而引發(fā)微信服務(wù)器負載異常,默認情況下,每個公眾號調(diào)用接口都不能超過一定限制,這里微信限制每天2000次。所以,如果我們想要頻繁調(diào)用這個參數(shù),需要我們開發(fā)者手動保存,每個access_token有效期是2個小時。
獲取接口調(diào)用憑證access_token
•官網(wǎng)文檔給出這樣解釋:
◦接口調(diào)用請求說明
http請求方式: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
■返回說明
正常情況下,微信會返回下述JSON數(shù)據(jù)包給公眾號:
{“access_token”:”ACCESS_TOKEN”,”expires_in”:7200}
錯誤時微信會返回錯誤碼等信息,JSON數(shù)據(jù)包示例如下(該示例為AppID無效錯誤):
{“errcode”:40013,”errmsg”:”invalid appid”}
•理解:
◦GET請求,該方式直接在本地就可以實現(xiàn)。因為只是一個普通的GET請求,類似于訪問網(wǎng)址。所以,不需要上傳該部分代碼到服務(wù)器就可以直接操作。
◦http請求協(xié)議是GET請求,說明我們需要通過GET請求獲取返回流,返回流是json形式。調(diào)用時我們需要攜帶三個參數(shù):grant_type、appid、secret。其中appid和secret是我們微信公眾號關(guān)鍵的參數(shù),在前文已經(jīng)闡述。返回結(jié)果分為正確和錯誤兩種結(jié)果?!景俣龋簀son】
◦其實,我們可以直接在地址欄輸入文檔給的示例:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET,我們會看到這樣的信息:“{“errcode”:40013,”errmsg”:”invalid appid hint: [pQKl0120ic11]”}”,因為這是一個無效的請求,返回的是錯誤的結(jié)果。
◦當我們把自己的測試號APPID和APPSECRET替換上面的那兩個參數(shù),會看到這樣的信息:“{“access_token”:”XrllR3fNf…bADAMIO”,”expires_in”:7200}”,代表獲取成功。
◦現(xiàn)在我們通過java 代碼獲取返回流,拿取access_token。
•實現(xiàn)
private static final long MAX_TIME = 7200 * 1000;// 微信允許最長Access_token有效時間(ms) private static final String TAG = "WeixinApiTest";// TAG private static final String APPID = "wx889b****b3666b0b8";// APPID private static final String SECERT = "6da7676***f0a9f15fbf06027856bb";// 秘鑰 /* * 該測試用例演示了如何獲取access_token。 * access_token是公眾號的全局唯一票據(jù),公眾號調(diào)用各接口時都需使用access_token。 */ @Test public void getAccess_token() throws IOException { // 拼接api要求的httpsurl鏈接 String urlString = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + APPID + "&secret=" + SECERT; // 創(chuàng)建一個url URL reqURL = new URL(urlString); // 拿取鏈接 HttpsURLConnection httpsConn = (HttpsURLConnection) reqURL .openConnection(); // 取得該連接的輸入流,以讀取響應(yīng)內(nèi)容 InputStreamReader isr = new InputStreamReader( httpsConn.getInputStream()); // 讀取服務(wù)器的響應(yīng)內(nèi)容并顯示 char[] chars = new char[1024]; String reslut = ""; int len; while ((len = isr.read(chars)) != -1) { reslut += new String(chars, 0, len); } isr.close(); /* * 轉(zhuǎn)化json成javabean。引入了第三方j(luò)ar:GSON */ Gson gson = new Gson();// 將獲取的json轉(zhuǎn)化為java中的bean // 注意:Access_token access_token是一個自己創(chuàng)建的javabean Access_token access_token = gson.fromJson(reslut, new Access_token().getClass()); if (access_token.getAccess_token() != null) { System.out.println("獲取的access_token是:" + access_token.getAccess_token()); System.out.println("該access_token的有效時間是:" + access_token.getExpires_in() + "s"); } else { System.out.println(TAG + "獲取access_token失敗,請檢查"); } }
保存接口調(diào)用憑證access_token
•思路
將獲取到的Access_token和當前時間存儲到file里, 取出時判斷當前時間和存儲里面的記錄的時間的時間差,如果大于MAX_TIME,重新獲取,并且將獲取到的存儲到file替換原來的內(nèi)容,如果小于MAX_TIME,直接獲取。
•實現(xiàn)
/* * 該方法實現(xiàn)獲取Access_token、保存并且只保存2小時Access_token。如果超過兩個小時重新獲?。蝗绻麤]有超過兩個小時,直接獲取。該方法依賴 * :public static String getAccessToken(); * * 思路:將獲取到的Access_token和當前時間存儲到file里, * 取出時判斷當前時間和存儲里面的記錄的時間的時間差,如果大于MAX_TIME,重新獲取,并且將獲取到的存儲到file替換原來的內(nèi)容 * ,如果小于MAX_TIME,直接獲取。 */ @Test public void getSavedAccess_token() throws IOException { Gson gson = new Gson(); String mAccess_token = null;// 需要獲取的Access_token; File file = new File("temp_access_token.temp");// Access_token保存的位置 // 如果文件不存在,創(chuàng)建 if (!file.exists()) file.createNewFile(); // 如果文件大小等于0,說明第一次使用,存入Access_token if (file.length() == 0) { mAccess_token = getAccessToken(); FileOutputStream fos = new FileOutputStream(file, false);// 不允許追加 Access_token at = new Access_token(); at.setAccess_token(mAccess_token); at.setExpires_in(System.currentTimeMillis() + ""); String json = gson.toJson(at); fos.write((json).getBytes()); fos.close(); } else { // 讀取文件內(nèi)容 FileInputStream fis = new FileInputStream(file); byte[] b = new byte[2048]; int len = fis.read(b); String mJsonAccess_token = new String(b, 0, len);// 讀取到的文件內(nèi)容 Access_token access_token = gson.fromJson(mJsonAccess_token, new Access_token().getClass()); if (access_token.getExpires_in() != null) { long saveTime = Long.parseLong(access_token.getExpires_in()); long nowTime = System.currentTimeMillis(); long remianTime = nowTime - saveTime; // System.out.println(TAG + "時間差:" + remianTime); if (remianTime < MAX_TIME) { Access_token at = gson.fromJson(mJsonAccess_token, new Access_token().getClass()); mAccess_token = at.getAccess_token(); } else { mAccess_token = getAccessToken(); FileOutputStream fos = new FileOutputStream(file, false);// 不允許追加 Access_token at = new Access_token(); at.setAccess_token(mAccess_token); at.setExpires_in(System.currentTimeMillis() + ""); String json = gson.toJson(at); fos.write((json).getBytes()); fos.close(); } } } System.out.println("獲取到的Access_token是:" + mAccess_token); } /* * 獲取微信服務(wù)器AccessToken。該部分和getAccess_token() 一致,不再加注釋 */ public static String getAccessToken() { String urlString = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + APPID + "&secret=" + SECERT; String reslut = null; try { URL reqURL = new URL(urlString); HttpsURLConnection httpsConn = (HttpsURLConnection) reqURL .openConnection(); InputStreamReader isr = new InputStreamReader( httpsConn.getInputStream()); char[] chars = new char[1024]; reslut = ""; int len; while ((len = isr.read(chars)) != -1) { reslut += new String(chars, 0, len); } isr.close(); } catch (IOException e) { e.printStackTrace(); } Gson gson = new Gson(); Access_token access_token = gson.fromJson(reslut, new Access_token().getClass()); if (access_token.getAccess_token() != null) { return access_token.getAccess_token(); } else { return null; } }
前三篇文章演示源碼:http://xiazai.jb51.net/201606/yuanma/WeixinApiDemo(jb51.net).rar
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- java獲取ip地址與網(wǎng)絡(luò)接口的方法示例
- java網(wǎng)絡(luò)編程之識別示例 獲取主機網(wǎng)絡(luò)接口列表
- Java判斷2個List集合是否相等(不考慮元素的順序)
- Java集合定義與用法實例總結(jié)【Set、List與Map】
- Java8中利用stream對map集合進行過濾的方法
- java使用lambda表達式對List集合進行操作技巧(JDK1.8)
- Java實現(xiàn)過濾掉map集合中key或value為空的值示例
- 詳細分析Java并發(fā)集合ArrayBlockingQueue的用法
- java拓展集合工具類CollectionUtils
- Java動態(tài)獲取實現(xiàn)某個接口下所有的實現(xiàn)類對象集合
相關(guān)文章
淺談Java中向上造型向下造型和接口回調(diào)中的問題
這篇文章主要介紹了淺談Java中向上造型向下造型和接口回調(diào)中的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08Java基礎(chǔ)之刪除文本文件中特定行的內(nèi)容
這篇文章主要介紹了Java基礎(chǔ)之刪除文本文件中特定行的內(nèi)容,文中有非常詳細的代碼示例,對正在學習java基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-04-04Java微信公眾平臺開發(fā)(5) 文本及圖文消息回復的實現(xiàn)
這篇文章主要為大家詳細介紹了Java微信公眾平臺開發(fā)第五步,回文本及圖文消息回復的實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04SpringCloud組件OpenFeign之默認HTTP請求方式詳解
這篇文章主要介紹了SpringCloud組件OpenFeign之默認HTTP請求方式詳解,在SpringMvcContract類中有個這樣的方法processAnnotationOnMethod,見名思意,這個方法就是處理Feign接口下方法上的注解的,需要的朋友可以參考下2024-01-01Java數(shù)據(jù)結(jié)構(gòu)之線性表
線性表是其組成元素間具有線性關(guān)系的一種數(shù)據(jù)結(jié)構(gòu),對線性表的基本操作主要有,獲取元素,設(shè)置元素值,遍歷,插入,刪除,查找,替換,排序等。而線性表可以采用順序儲存結(jié)構(gòu)和鏈式儲存結(jié)構(gòu),本節(jié)主要講解順序表、單鏈表以及雙鏈表的各種基本操作。2017-03-03