程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java微信開辟API第三步 微信獲得和保留接口挪用憑證

java微信開辟API第三步 微信獲得和保留接口挪用憑證

編輯:關於JAVA

java微信開辟API第三步 微信獲得和保留接口挪用憑證。本站提示廣大學習愛好者:(java微信開辟API第三步 微信獲得和保留接口挪用憑證)文章只能為提供參考,不一定能成為您想要的結果。以下是java微信開辟API第三步 微信獲得和保留接口挪用憑證正文


微信若何獲得和保留接口挪用憑證,上面就為年夜家停止引見

1、解釋
*具體解釋請參考前兩篇文章。
*本文分為三部門:
    接口挪用憑證access_token的感化和說明
    若何獲得接口挪用憑證access_token
    若何完成微信文檔所說的“中控辦事器”的完成以保留access_token
* 本文停止會給出包含本文前三篇文章的一切演示源碼

 為何要獲得和保留接口挪用憑證access_token
 •開端開辟-獲得接口挪用憑證
◦文檔地址:http://mp.weixin.qq.com/wiki/14/9f9c82c1af308e3b14ba9b973f99a8ba.html

 •官網文檔給出如許說明:
◦access_token是"號的全局獨一單子,"號挪用各接口時都需應用access_token。開辟者須要停止妥當保留。access_token的存儲至多要保存512個字符空間。access_token的有用期今朝為2個小時,需准時刷新,反復獲得將招致前次獲得的access_token掉效。

 •懂得:
◦我們簡略翻閱文檔可以發明,很多高等功效,例如:自界說菜單、素材治理、用戶治理、賬號治理等各類高等功效要求的鏈接中都有“?access_token=TOKEN”這個參數,這是全局挪用參數,微信後台須要依據這個參數肯定身份,包管我們的微信"號的平安。
 ◦為了避免"號的法式毛病而激發微佩服務器負載異常,默許情形下,每一個"號挪用接口都不克不及跨越必定限制,這裡微信限制天天2000次。所以,假如我們想要頻仍挪用這個參數,須要我們開辟者手動保留,每一個access_token有用期是2個小時。

獲得接口挪用憑證access_token
•官網文檔給出如許說明:
◦接口挪用要求解釋

http要求方法: GET
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
■前往解釋

正常情形下,微信會前往下述JSON數據包給"號:
{“access_token”:”ACCESS_TOKEN”,”expires_in”:7200}

毛病時微信會前往毛病碼等信息,JSON數據包示例以下(該示例為AppID有效毛病):
{“errcode”:40013,”errmsg”:”invalid appid”}

•懂得:
◦GET要求,該方法直接在當地便可以完成。由於只是一個通俗的GET要求,相似於拜訪網址。所以,不須要上傳該部門代碼到辦事器便可以直接操作。
 ◦http要求協定是GET要求,解釋我們須要經由過程GET要求獲得前往流,前往流是json情勢。挪用時我們須要攜帶三個參數:grant_type、appid、secret。個中appid和secret是我們微信"號症結的參數,在前文曾經論述。前往成果分為准確和毛病兩種成果。【百度:json】
 ◦其實,我們可以直接在地址欄輸出文檔給的示例:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET,我們會看到如許的信息:“{“errcode”:40013,”errmsg”:”invalid appid hint: [pQKl0120ic11]”}”,由於這是一個有效的要求,前往的是毛病的成果。
 ◦當我們把本身的測試號APPID和APPSECRET調換下面的那兩個參數,會看到如許的信息:“{“access_token”:”XrllR3fNf…bADAMIO”,”expires_in”:7200}”,代表獲得勝利。
 ◦如今我們經由過程java 代碼獲得前往流,拿取access_token。

 •完成

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是"號的全局獨一單子,"號挪用各接口時都需應用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;
  // 創立一個url
  URL reqURL = new URL(urlString);
  // 拿取鏈接
  HttpsURLConnection httpsConn = (HttpsURLConnection) reqURL
      .openConnection();
  // 獲得該銜接的輸出流,以讀取呼應內容
  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);
  }
  isr.close();
  /*
   * 轉化json成javabean。引入了第三方jar:GSON
   */
  Gson gson = new Gson();// 將獲得的json轉化為java中的bean
  // 留意:Access_token access_token是一個本身創立的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掉敗,請檢討");

  }

}

保留接口挪用憑證access_token
 •思緒

將獲得到的Access_token和以後時光存儲到file裡, 掏出時斷定以後時光和存儲外面的記載的時光的時光差,假如年夜於MAX_TIME,從新獲得,而且將獲得到的存儲到file調換本來的內容,假如小於MAX_TIME,直接獲得。

 •完成

  /*
   * 該辦法完成獲得Access_token、保留而且只保留2小時Access_token。假如跨越兩個小時從新獲得;假如沒有跨越兩個小時,直接獲得。該辦法依附
   * :public static String getAccessToken();
   * 
   * 思緒:將獲得到的Access_token和以後時光存儲到file裡,
   * 掏出時斷定以後時光和存儲外面的記載的時光的時光差,假如年夜於MAX_TIME,從新獲得,而且將獲得到的存儲到file調換本來的內容
   * ,假如小於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保留的地位
    // 假如文件不存在,創立
    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 {
      // 讀取文件內容
      FileInputStream fis = new FileInputStream(file);
      byte[] b = new byte[2048];
      int len = fis.read(b);
      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);
        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);
  }

  /*
   * 獲得微佩服務器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

以上就是本文的全體內容,願望對年夜家的進修有所贊助,也願望年夜家多多支撐。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved