java微信开发API第三步 微信获取以及保存接口调用凭证

微信如何获取以及保存接口调用凭证,下面就为大家进行介绍

一、说明
*详细说明请参考前两篇文章。
*本文分为三部分:
    接口调用凭证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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 微信开发之使用java获取签名signature

    一.前言 微信接口调用验证最终需要用到的三个参数noncestr.timestamp.signature: 接下来将会给出获取这三个参数的详细代码 本文的环境eclipse + maven 本文使用到的技术HttpClient.Json字符串转map.sha1加密 二.需要用到的jar包 maven依赖的包有: 1.HttpClient包依赖 <dependency> <groupId>org.apache.httpcomponents</groupId> <ar

  • Java的微信开发中使用XML格式和JSON格式数据的示例

    XML 微信XML消息model定义: package cn.wx.server; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.DocumentHelper; import org.dom4j.Element; /** * @title cn.wx.serverXMLMsg.java * @todo TODO * @author lpe234 * @time 2014年5月21日下

  • Java微信公众平台开发(6) 微信开发中的token获取

    (一)token的介绍 引用:access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token.开发者需要进行妥善保存.access_token的存储至少要保留512个字符空间.access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效! (二)token的获取参考文档 获取的流程我们完全可以参考微信官方文档:http://mp.weixin.qq.com/wiki/14/9f9c82c1af308e3b14

  • Java微信公众平台开发(7) 公众平台测试帐号的申请

    前面几篇一直都在写一些比较基础接口的使用,在这个过程中一直使用的都是我个人微博认证的一个个人账号,原本准备这篇是写[多媒体消息回复]的,后来主要到我个人账号的接口权限不够,所以在这里插入一篇[公众平台测试帐号的申请]的文章,同时也提醒各位开发者一定要注意在开发过程中需要注意接口权限,以防想当然的写完代码才发现接口不能使用,但是同样的我们也可以先预演接口的功能然后再将其应用到实际中! ①登入到微信公众平台,我们到[开发]-->[开发者工具]-->[公众平台测试账号]--进入: 首次进入可能会需要

  • java微信开发API第四步 微信自定义个性化菜单实现

    微信如何实现自定义个性化菜单,下面为大家介绍 一.全局说明 详细说明请参考前两篇文章. 二.本文说明 本文分为五部分:     * 工具类AccessTokenUtils的封装     * 自定义菜单和个性化菜单文档的阅读解析     * 菜单JSON的分析以及构建对应bean     * 自定义菜单的实现     * 个性化菜单的实现 微信自定义菜单所有类型菜单都给出演示 本文结束会给出包括本文前四篇文章的所有演示源码 工具类AccessTokenUtils的封装 在上文中关于AccessTo

  • java微信开发第二步 获取消息和回复消息

    接着上一篇java微信开发API第一步 服务器接入进行学习,下面介绍java微信开发第二步:获取消息和回复消息,具体内容如下 * 本示例根据微信开发文档:http://mp.weixin.qq.com/wiki/home/index.html最新版(4/3/2016 5:34:36 PM )进行开发演示. * 编辑平台:myeclipse10.7+win32+jdk1.7+tomcat7.0  * 服务器:阿里云 windows server 2008 64bits * 平台要求:servlet

  • java微信开发之上传下载多媒体文件

    回复图片.音频.视频消息都是需要media_id的,这个是需要将多媒体文件上传到微信服务器才有的. 将多媒体文件上传到微信服务器,以及从微信服务器下载文件,可以参考:http://mp.weixin.qq.com/wiki/index.php?title=上传下载多媒体文件 上传下载多媒体文件的方法还是写到WeixinUtil.java中. 代码如下: import java.io.BufferedOutputStream; import java.io.BufferedReader; impo

  • java微信开发API第一步 服务器接入

    微信开发API如何接入服务器,下面就为大家进行介绍 一.说明 * 本示例根据微信开发文档:http://mp.weixin.qq.com/wiki/home/index.html最新版(4/3/2016 5:34:36 PM )进行开发演示. * 编辑平台:myeclipse10.7+win32+jdk1.7+tomcat7.0  * 服务器:阿里云 windows server 2008 64bits * 平台要求:servlet使用注解方式,平台要求:j2ee6.0+.jdk6.0+.tom

  • java微信开发API第二步 获取和回复消息

    微信开发API如何获取和回复消息,下面就为大家进行介绍 一.说明 * 本示例根据微信开发文档:http://mp.weixin.qq.com/wiki/home/index.html最新版(4/3/2016 5:34:36 PM )进行开发演示. * 编辑平台:myeclipse10.7+win32+jdk1.7+tomcat7.0  * 服务器:阿里云 windows server 2008 64bits * 平台要求:servlet使用注解方式,平台要求:j2ee6.0+.jdk6.0+.t

  • java微信开发API第三步 微信获取以及保存接口调用凭证

    微信如何获取以及保存接口调用凭证,下面就为大家进行介绍 一.说明 *详细说明请参考前两篇文章. *本文分为三部分:     接口调用凭证access_token的作用以及解释     如何获取接口调用凭证access_token     如何实现微信文档所说的"中控服务器"的实现以保存access_token * 本文结束会给出包括本文前三篇文章的所有演示源码  为什么要获取和保存接口调用凭证access_token  •开始开发-获取接口调用凭据 ◦文档地址:http://mp.we

  • 微信开发 网页授权获取用户基本信息

    微信公众平台最近新推出微信认证,认证后可以获得高级接口权限,其中一个是OAuth2.0网页授权,很多朋友在使用这个的时候失败了或者无法理解其内容,希望我出个教程详细讲解一下,于是便有了这篇文章. 一.什么是OAuth2.0 官方网站:http://oauth.net/   http://oauth.net/2/ 权威定义:OAuth is An open protocol to allow secure authorization in a simple and standard method

  • 比较完整的微信开发php代码

    本文实例为大家分享了微信开发php代码,供大家参考,具体内容如下 <?php //封装成一个微信接口类 class WeixinApi { private $appid; private $appsecret; //构造方法 初始化赋值 public function __construct($appid="",$appsecret="") { $this->appid = $appid; $this->appsecret = $appsecret

  • 微信开发之网页授权获取用户信息(二)

    在公众号的配置过程中,许多开发者会在菜单中加入HTML5页面,有时在页面内需要访问页面的用户信息,此时就需要网页授权获取用户基本信息 我们提醒大家:本文介绍讲述的内容是基于yii2.0框架 1.设置授权回调域名:开发 ---> 接口权限 找到"网页授权获取用户基本信息",点击后面对应的"修改",在弹框响应位置填写授权回调域名即可,此处的域名不需要加http:// (关于网页授权回调域名的说明详情可参考公众平台开发者文档) 2.获取授权 关于OAuth2.0博主

  • Python实现的微信支付方式总结【三种方式】

    本文实例讲述了Python实现的微信支付方式.分享给大家供大家参考,具体如下: 一.准备环境 1.要有微信公众号,商户平台账号 https://pay.weixin.qq.com/wiki/doc/api/index.html 2.支持的支付方式有 3.备案域名 选择扫码支付,如果使用模式二则不需要域名,只需要可访问的ip地址就行. 4.建一个Django项目. 一.扫码支付 点击"扫码支付"按官方文档配置好回调url(具体如何配置看官网) 先从公众号上获取APP_ID,APP_SEC

  • java多线程开发ScheduledExecutorService简化方式

    目录 前言 java多线程的应用场景 应用场景一: 应用场景二: ScheduledExecutorService方法简介 实例 实例结果 前言 java开发,多多少少会接触到多线程的应用开发场景,博主之前做多线程的时候就两种方式,一个是继承Thread一个是实现Runnable接口,不过用的多的还是实现Runnable接口,因为实现Runnable接口可以做多线程资源共享!而java.util.concurrent.ScheduledExecutorService接口将大大简化多线程应用的开发

随机推荐