溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信公眾平臺怎么獲取access_token

發(fā)布時間:2021-05-22 11:42:25 來源:億速云 閱讀:198 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關微信公眾平臺怎么獲取access_token的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

前言:access_token是微信公眾平臺接口的重要參數,很多接口都需要這個參數。

一、access_token說明

access_token是公眾號的全局唯一接口調用憑據,公眾號調用各接口時都需使用access_token。開發(fā)者需要進行妥善保存。access_token的存儲至少要保留512個字符空間。access_token的有效期目前為2個小時,需定時刷新,重復獲取將導致上次獲取的access_token失效。

1:公眾平臺的API調用所需的access_token的使用

1、建議公眾號開發(fā)者使用中控服務器統(tǒng)一獲取和刷新Access_token,其他業(yè)務邏輯服務器所使用的access_token均來自于該中控服務器,不應該各自去刷新,否則容易造成沖突,導致access_token覆蓋而影響業(yè)務;
2、目前Access_token的有效期通過返回的expire_in來傳達,目前是7200秒之內的值。中控服務器需要根據這個有效時間提前去刷新新access_token。在刷新過程中,中控服務器對外輸出的依然是老access_token,此時公眾平臺后臺會保證在刷新短時間內,新老access_token都可用,這保證了第三方業(yè)務的平滑過渡;
3、Access_token的有效時間可能會在未來有調整,所以中控服務器不僅需要內部定時主動刷新,還需要提供被動刷新access_token的接口,這樣便于業(yè)務服務器在API調用獲知access_token已超時的情況下,可以觸發(fā)access_token的刷新流程。

2:access_token的生成說明

公眾號可以使用AppID和AppSecret調用本接口來獲取access_token。AppID和AppSecret可在“微信公眾平臺-開發(fā)-基本配置”頁中獲得(需要已經成為開發(fā)者,且?guī)ぬ枦]有異常狀態(tài))。調用接口時,請登錄“微信公眾平臺-開發(fā)-基本配置”提前將服務器IP地址添加到IP白名單中,點擊查看設置方法,否則將無法調用成功。

微信公眾平臺怎么獲取access_token

二、接口調用請求說明

1:接口調用

https請求方式: GET

https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

2:參數說明

參數是否必須說明
grant_type獲取access_token填寫client_credential
appid第三方用戶唯一憑證
secret第三方用戶唯一憑證密鑰,即appsecret

3:返回說明

正常情況下,微信會返回下述JSON數據包給公眾號:

{"access_token":"ACCESS_TOKEN","expires_in":7200}

參數說明

參數說明
access_token獲取到的憑證
expires_in憑證有效時間,單位:秒

錯誤時微信會返回錯誤碼等信息,JSON數據包示例如下(該示例為AppID無效錯誤):

{"errcode":40013,"errmsg":"invalid appid"}

4:返回碼說明

返回碼說明
-1系統(tǒng)繁忙,此時請開發(fā)者稍候再試
0請求成功
40001AppSecret錯誤或者AppSecret不屬于這個公眾號,請開發(fā)者確認AppSecret的正確性
40002請確保grant_type字段值為client_credential
40164調用接口的IP地址不在白名單中,請在接口IP白名單中進行設置

三、java接口開發(fā)

1:返回接口封裝類Token

/**
 * 類名: Token.java</br> 
 * 描述: 憑證</br> 
 */
public class Token {
  // 接口訪問憑證
  private String accessToken;
  // 憑證有效期,單位:秒
  private int expiresIn;

  public String getAccessToken() {
    return accessToken;
  }

  public void setAccessToken(String accessToken) {
    this.accessToken = accessToken;
  }

  public int getExpiresIn() {
    return expiresIn;
  }

  public void setExpiresIn(int expiresIn) {
    this.expiresIn = expiresIn;
  }
}

2:獲取接口訪問憑證

  /**
   * 獲取接口訪問憑證
   * @param appid 憑證
   * @param appsecret 密鑰
   * @return
   */
  public static Token getToken(String appid, String appsecret) {
    Token token = null;
    String requestUrl = WeixinConstants.TOKEN_URL.replace("APPID", appid).replace("APPSECRET", appsecret);
    // 發(fā)起GET請求獲取憑證
    JSONObject jsonObject = httpsRequest(requestUrl, "GET", null);

    if (null != jsonObject) {
      try {
        token = new Token();
        token.setAccessToken(jsonObject.getString("access_token"));
        token.setExpiresIn(jsonObject.getInt("expires_in"));
      } catch (JSONException e) {
        token = null;
        // 獲取token失敗
        log.error("獲取token失敗 errcode:{} errmsg:{}", jsonObject.getInt("errcode"), jsonObject.getString("errmsg"));
      }
    }
    return token;
  }

3:http請求工具類

  /**
   * 發(fā)送https請求
   * @param requestUrl 請求地址
   * @param requestMethod 請求方式(GET、POST)
   * @param outputStr 提交的數據
   * @return JSONObject(通過JSONObject.get(key)的方式獲取json對象的屬性值)
   */
  public static JSONObject httpsRequest(String requestUrl, String requestMethod, String outputStr) {
    JSONObject jsonObject = null;
    try {
      // 創(chuàng)建SSLContext對象,并使用我們指定的信任管理器初始化
      TrustManager[] tm = { new MyX509TrustManager() };
      SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
      sslContext.init(null, tm, new java.security.SecureRandom());
      // 從上述SSLContext對象中得到SSLSocketFactory對象
      SSLSocketFactory ssf = sslContext.getSocketFactory();

      URL url = new URL(requestUrl);
      HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
      conn.setSSLSocketFactory(ssf);

      conn.setDoOutput(true);
      conn.setDoInput(true);
      conn.setUseCaches(false);
      // 設置請求方式(GET/POST)
      conn.setRequestMethod(requestMethod);

      // 當outputStr不為null時向輸出流寫數據
      if (null != outputStr) {
        OutputStream outputStream = conn.getOutputStream();
        // 注意編碼格式
        outputStream.write(outputStr.getBytes("UTF-8"));
        outputStream.close();
      }

      // 從輸入流讀取返回內容
      InputStream inputStream = conn.getInputStream();
      InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");
      BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
      String str = null;
      StringBuffer buffer = new StringBuffer();
      while ((str = bufferedReader.readLine()) != null) {
        buffer.append(str);
      }

      // 釋放資源
      bufferedReader.close();
      inputStreamReader.close();
      inputStream.close();
      inputStream = null;
      conn.disconnect();
      jsonObject = JSONObject.fromObject(buffer.toString());
    } catch (ConnectException ce) {
      log.error("連接超時:{}", ce);
    } catch (Exception e) {
      log.error("https請求異常:{}", e);
    }
    return jsonObject;
  }

4:信任管理器工具類

/**
 * 類名: MyX509TrustManager.java</br> 
 * 描述: 信任管理器</br> 
 */
public class MyX509TrustManager implements X509TrustManager {

  // 檢查客戶端證書
  public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
  }

  // 檢查服務器端證書
  public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
  }

  // 返回受信任的X509證書數組
  public X509Certificate[] getAcceptedIssuers() {
    return null;
  }
}

感謝各位的閱讀!關于“微信公眾平臺怎么獲取access_token”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI