java微信開辟API第四步 微信自界說特性化菜單完成。本站提示廣大學習愛好者:(java微信開辟API第四步 微信自界說特性化菜單完成)文章只能為提供參考,不一定能成為您想要的結果。以下是java微信開辟API第四步 微信自界說特性化菜單完成正文
微信若何完成自界說特性化菜單,上面為年夜家引見
1、全局解釋
具體解釋請參考前兩篇文章。
2、本文解釋
本文分為五部門:
* 對象類AccessTokenUtils的封裝
* 自界說菜單和特性化菜單文檔的浏覽解析
* 菜單JSON的剖析和構建對應bean
* 自界說菜單的完成
* 特性化菜單的完成
微信自界說菜單一切類型菜單都給出演示
本文停止會給出包含本文前四篇文章的一切演示源碼
對象類AccessTokenUtils的封裝
在上文中關於AccessToken的獲得和准時保留曾經具體引見過,此處直接給出處置過以後封裝的AccessTokenUtils,完成道理和文檔浏覽不再給出。
AccessTokenUtils.java
package com.gist.utils;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.URL;
import javax.net.ssl.HttpsURLConnection;
import com.gist.bean.Access_token;
import com.谷歌.gson.Gson;
/**
* @author 高遠</n> 郵箱:wgyscsf@163.com</n> 博客 http://blog.csdn.net/wgyscsf</n>
* 編寫時代 2016-4-7 下晝5:44:33
*/
public class AccessTokenUtils {
private static final long MAX_TIME = 7200 * 1000;// 微信許可最長Access_token有用時光(ms)
private static final String TAG = "WeixinApiTest";// TAG
private static final String APPID = "wx889b020b3666b0b8";// APPID
private static final String SECERT = "6da7676bf394f0a9f15fbf06027856bb";// 秘鑰
/*
* 該辦法完成獲得Access_token、保留而且只保留2小時Access_token。假如跨越兩個小時從新獲得;假如沒有跨越兩個小時,直接獲得。該辦法依附
* :public static String getAccessToken();
*
* 思緒:將獲得到的Access_token和以後時光存儲到file裡,
* 掏出時斷定以後時光和存儲外面的記載的時光的時光差,假如年夜於MAX_TIME,從新獲得,而且將獲得到的存儲到file調換本來的內容
* ,假如小於MAX_TIME,直接獲得。
*/
// 為了挪用不拋異常,這裡全體捕獲異常,代碼有點長
public static String getSavedAccess_token() {
Gson gson = new Gson();// 第三方jar,處置json和bean的轉換
String mAccess_token = null;// 須要獲得的Access_token;
FileOutputStream fos = null;// 輸入流
FileInputStream fis = null;// 輸出流
File file = new File("temp_access_token.temp");// Access_token保留的地位
try {
// 假如文件不存在,創立
if (!file.exists()) {
file.createNewFile();
}
} catch (Exception e1) {
e1.printStackTrace();
}
// 假如文件年夜小等於0,解釋第一次應用,存入Access_token
if (file.length() == 0) {
try {
mAccess_token = getAccessToken();// 獲得AccessToken
Access_token at = new Access_token();
at.setAccess_token(mAccess_token);
at.setExpires_in(System.currentTimeMillis() + "");// 設置存入時光
String json = gson.toJson(at);
fos = new FileOutputStream(file, false);// 不許可追加
fos.write((json).getBytes());// 將AccessToken和以後時光存入文件
fos.close();
return mAccess_token;
} catch (Exception e) {
e.printStackTrace();
}
} else {
// 讀取文件內容
byte[] b = new byte[2048];
int len = 0;
try {
fis = new FileInputStream(file);
len = fis.read(b);
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
String mJsonAccess_token = new String(b, 0, len);// 讀取到的文件內容
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 + "ms");
if (remianTime < MAX_TIME) {
Access_token at = gson.fromJson(mJsonAccess_token,
new Access_token().getClass());
mAccess_token = at.getAccess_token();
return mAccess_token;
} else {
mAccess_token = getAccessToken();
Access_token at = new Access_token();
at.setAccess_token(mAccess_token);
at.setExpires_in(System.currentTimeMillis() + "");
String json = gson.toJson(at);
try {
fos = new FileOutputStream(file, false);// 不許可追加
fos.write((json).getBytes());
fos.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return mAccess_token;
}
} else {
return null;
}
}
return mAccess_token;
}
/*
* 獲得微佩服務器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://mp.weixin.qq.com/wiki/10/0234e39a2025342c17a7d23595c6b40a.html
•官網文檔給出如許說明:
* 自界說菜單接口可完成多品種型按鈕,以下:1、click:點擊事宜...;2、view:跳轉事宜...;3、...(關於自界說菜單)
* 接口挪用要求解釋 http要求方法:POST(請應用https協定) https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN(關於自界說菜單)
* click和view的要求示例 {"button":[...]} (關於自界說菜單)
* 參數解釋...(關於自界說菜單)
* 創立特性化菜單http要求方法:POST(請應用https協定)https://api.weixin.qq.com/cgi-bin/menu/addconditional?access_token=ACCESS_TOKEN(關於特性化菜單)
* 要求示例: {"button":[...],"matchrule":{...}}(關於特性化菜單)
* 參數解釋...(關於特性化菜單)
* 開辟者可以經由過程以下前提來設置用戶看到的菜單(關於特性化菜單):
1、用戶分組(開辟者的營業需求可以借助用戶分組來完成)
2、性別
3、手機操作體系
4、地域(用戶在微信客戶端設置的地域)
5、說話(用戶在微信客戶端設置的說話)
•懂得:
◦又是熟習的POST要求,然則,關於挪用貌似說的暧昧其辭,不太明確。只是曉得我們須要應用“?access_token=ACCESS_TOKEN”這個參數,這個參數我們在上篇文章曾經獲得到了。假設我們將微信文檔給的誰人要求地址中“ACCESS_TOKEN”換成我們獲得到的本身的ACCESS_TOKEN,拜訪該網址,會看到“{“errcode”:44002,”errmsg”:”empty post data hint: [Gdveda0984vr23]”}”。年夜概意思是,空的post要求數據。所以,我們要經由過程POST要求的情勢傳遞參數給微佩服務器,在文檔上面還給出了參數的格局:{“button”:[…]},所以,我們要依照該格局給微佩服務器停止傳遞參數。
◦關於參數解釋,我們可以看到在自界說菜單創立中有七個參數。在特性化菜單接口中除去這七個參數以外,別的多個八個參數。簡略檢查此部門文檔,我們可以懂得到這個八個參數是為了特性化菜單做婚配挑選用的。
◦如今,我們須要依照微信文檔的請求結構json經由過程post的要求向微佩服務器發送這一串json數據,json外面就包含我們創立的各類類型的按鈕事宜。
菜單JSON的剖析和構建對應bean
自界說菜單json剖析(不包含特性化菜單)。上面這段代碼是微信文檔給的示例。
click和view的要求示例
{
"button":[
{
"type":"click",
"name":"昔日歌曲",
"key":"V1001_TODAY_MUSIC"
},
{
"name":"菜單",
"sub_button":[
{
"type":"view",
"name":"搜刮",
"url":"http://www.soso.com/"
},
{
"type":"view",
"name":"視頻",
"url":"http://v.qq.com/"
},
{
"type":"click",
"name":"贊一下我們",
"key":"V1001_GOOD"
}]
}]
}
經由剖析我們可以看到這串json數據分為三層:“”button”:[{…},{…}]”、“[{…},{{“name”:菜單,”sub_button”:[{},{}]}]”、“{“type”:”view”,”name:”:”視頻”,”url”:”…”},{},{}”,能夠看起來比擬暈。
然則,假如我們可以或許聯想起來實際中看到的微信菜單,就會好懂得一點:一級:菜單(一個菜單),下包含一到三個父按鈕;二級:父按鈕(1~3個父按鈕),下包含一到五個子按鈕;三級:子按鈕(1~5個子按鈕)。
如今,我們可以看到json和我們懂得的“菜單”可以逐個對應起來了。如今重點是若何確認每級的“級名”,在java中也就是對應的javabean對象。
同時,由於一級菜單下會有多個父按鈕,所所以一個List<父菜單>的情勢。父按鈕下能夠有多個子菜單,也是一個 List<子菜單>;然則,父按鈕也有能夠也是一個零丁的可以呼應的按鈕。是一個零丁的父按鈕對象。子按鈕就是一個零丁的子按鈕對象。
檢查關於自界說菜單的參數解釋,我們可以看到按鈕分為一級按鈕(“button”)和二級按鈕(“sub_button”)。還有一些公用的數據類型,例如:菜單呼應類型(“type”)、菜單題目(“name”)、click類型的參數(“key”)、view類型的參數(“url”)、media_id類型和view_limited類型的參數(“media_id”)。
•數據籠統(沒有寫setter,getter):
//按鈕基類
public class BaseButton {
private String type;
private String name;
private String key;
private String url;
private String media_id;
}
//子按鈕
public class SonButton extends BaseButton {
private String sub_button;
}
//父按鈕
public class FatherButton extends BaseButton {
private String button;//能夠直接一個父按鈕做呼應
@SerializedName("sub_button")//為了包管Gson解析後子按鈕的名字是“sub_button”,詳細用法請搜刮
private List<SonButton> sonButtons;//能夠有多個子按鈕
}
public class Menu {
@SerializedName("button")
private List<FatherButton> fatherButtons;
}
以上是完全的自界說菜單的剖析和對應javabean的構建。
關於特性化菜單,假如檢查該部門的文檔,會發明和自界說菜單年夜致雷同,只是多個一個“設置裝備擺設”的json,格局是如許的:{“button”:[…],”matchrule”:{…}}。
我們發明,“婚配”這段json和“button”是同級的,剖析和完成和下面根本同等,直接給出完成的javabean。
//婚配的json對應的json
public class MatchRule {
private String group_id;
private String sex;
private String client_platform_type;
private String country;
private String province;
private String city;
private String language;
}
//修正Menu.java
public class Menu {
@SerializedName("button")
private List<FatherButton> fatherButtons;
private MatchRule matchrule;
}
自界說菜單的完成
義務,我們完成一切微信按鈕呼應類型:
義務(正文:“m-0”表現父按鈕;“m-n”表現第m個父按鈕,第n個子按鈕(m,n≠0)):1-0:名字:click,呼應點擊事宜:點擊推事宜 。2-0:名字:父按鈕2。2-1:名字:view,呼應事宜:跳轉網頁;2-2:名字:scancode_push,呼應事宜:掃碼推事宜;2-3:名字:scancode_waitmsg,呼應事宜:掃碼推事宜且彈出“新聞吸收中”提醒框;2-4:名字:pic_sysphoto,呼應事宜
:彈出體系攝影發圖。2-5:名字:pic_photo_or_album,呼應事宜:彈出攝影或許相冊發圖。3-0:名字:父按鈕3。3-1:名字
:pic_weixin,呼應事宜:彈出微信相冊發圖器;3-2:名字:location_select,呼應事宜:彈出地輿地位選擇器;3-3:名字:media_id,呼應事宜:下發新聞(除文本新聞);3-4:名字:view_limited,呼應事宜:跳轉圖文新聞url。
完成源碼(援用的AccessTokenUtils.java在第一部門:對象類AccessTokenUtils的封裝)
/*
* 創立自界說菜單。
*/
@Test
public void createCommMenu() {
String ACCESS_TOKEN = AccessTokenUtils.getAccessToken();// 獲得AccessToken,AccessTokenUtils是封裝好的類
// 拼接api請求的httpsurl鏈接
String urlString = "https://api.weixin.qq.com/cgi-bin/menu/create?access_token="
+ ACCESS_TOKEN;
try {
// 創立一個url
URL reqURL = new URL(urlString);
// 拿取鏈接
HttpsURLConnection httpsConn = (HttpsURLConnection) reqURL
.openConnection();
httpsConn.setDoOutput(true);
// 獲得該銜接的輸入流,以讀取呼應內容
OutputStreamWriter osr = new OutputStreamWriter(
httpsConn.getOutputStream());
osr.write(getMenuJson());// 應用本類內部辦法getMenuJson()
osr.close();
// 前往成果
InputStreamReader isr = new InputStreamReader(
httpsConn.getInputStream());
// 讀取辦事器的呼應內容並顯示
char[] chars = new char[1024];
String reslut = "";
int len;
while ((len = isr.read(chars)) != -1) {
reslut += new String(chars, 0, len);
}
System.out.println("前往成果:" + reslut);
isr.close();
} catch (IOException e) {
e.printStackTrace();
}
}
public String getMenuJson() {
Gson gson = new Gson();// json處置對象
Menu menu = new Menu();// 菜單類
List<FatherButton> fatherButtons = new ArrayList<FatherButton>();// 菜單中的父按鈕聚集
// -----------
// 父按鈕1
FatherButton fb1 = new FatherButton();
fb1.setName("click");
fb1.setType("click");
fb1.setKey("10");
// -------------
// 父按鈕2
FatherButton fb2 = new FatherButton();
fb2.setName("父按鈕2");
List<SonButton> sonButtons2 = new ArrayList<SonButton>();// 子按鈕的聚集
// 子按鈕2-1
SonButton sb21 = new SonButton();
sb21.setName("view");
sb21.setUrl("http://www.百度.com");
sb21.setType("view");
// 子按鈕2-2
SonButton sb22 = new SonButton();
sb22.setName("scancode_push");
sb22.setType("scancode_push");
sb22.setKey("22");
// 子按鈕2-3
SonButton sb23 = new SonButton();
sb23.setName("scancode_waitmsg");
sb23.setType("scancode_waitmsg");
sb23.setKey("23");
// 子按鈕2-4
SonButton sb24 = new SonButton();
sb24.setName("pic_sysphoto");
sb24.setType("pic_sysphoto");
sb24.setKey("24");
// 子按鈕2-5
SonButton sb25 = new SonButton();
sb25.setName("pic_photo_or_album");
sb25.setType("pic_photo_or_album");
sb25.setKey("25");
// 添加子按鈕到子按鈕聚集
sonButtons2.add(sb21);
sonButtons2.add(sb22);
sonButtons2.add(sb23);
sonButtons2.add(sb24);
sonButtons2.add(sb25);
// 將子按鈕放到2-0父按鈕聚集
fb2.setSonButtons(sonButtons2);
// ------------------
// 父按鈕3
FatherButton fb3 = new FatherButton();
fb3.setName("父按鈕3");
List<SonButton> sonButtons3 = new ArrayList<SonButton>();
// 子按鈕3-1
SonButton sb31 = new SonButton();
sb31.setName("pic_weixin");
sb31.setType("pic_weixin");
sb31.setKey("31");
// 子按鈕3-2
SonButton sb32 = new SonButton();
sb32.setName("locatselect");
sb32.setType("location_select");
sb32.setKey("32");
// // 子按鈕3-3-->測試不了,由於要media_id。這須要挪用素材id.
// SonButton sb33 = new SonButton();
// sb33.setName("media_id");
// sb33.setType("media_id");
// sb33.setMedia_id("???");
// // 子按鈕3-4-->測試不了,由於要media_id。這須要挪用素材id.
// SonButton sb34 = new SonButton();
// sb34.setName("view_limited");
// sb34.setType("view_limited");
// sb34.setMedia_id("???");
// 添加子按鈕到子按鈕隊列
sonButtons3.add(sb31);
sonButtons3.add(sb32);
// sonButtons3.add(sb33);
// sonButtons3.add(sb34);
// 將子按鈕放到3-0父按鈕隊列
fb3.setSonButtons(sonButtons3);
// ---------------------
// 將父按鈕參加到父按鈕聚集
fatherButtons.add(fb1);
fatherButtons.add(fb2);
fatherButtons.add(fb3);
// 將父按鈕隊列參加到菜單欄
menu.setFatherButtons(fatherButtons);
String json = gson.toJson(menu);
System.out.println(json);// 測試輸入
return json;
}
特性化菜單的完成
•義務:依據性別展現分歧的按鈕顯示(可以依據性別、地域、分組手機操作體系等)
•修正代碼一,由於是分歧的微信後台完成,所以接口也紛歧樣,不外照樣POST要求,代碼不消改,只需調換本來urlString便可。
// 拼接api請求的httpsurl鏈接 String urlString = "https://api.weixin.qq.com/cgi-bin/menu/addconditional?access_token=" + ACCESS_TOKEN;
•修正代碼二,只需創立一個MatchRule,設置婚配規矩,然後將matchrule參加到menu即可以完成婚配規矩。
// -----
// 從此處開端設置特性菜單
MatchRule matchrule = new MatchRule();
matchrule.setSex("2");// 男生
menu.setMatchrule(matchrule);
// ----
源碼下載:http://xiazai.jb51.net/201606/yuanma/WeixinApi(jb51.net).rar
以上就是本文的全體內容,願望對年夜家的進修有所贊助,也願望年夜家多多支撐。