UDN-企业互联网技术人气社区

板块导航

浏览  : 3060
回复  : 5

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

[复制链接]
西北的风的头像 楼主
发表于 2017-1-17 17:17:41 | 显示全部楼层 |阅读模式
    这篇文章主要为大家详细介绍了java微信开发API第二步,微信获取以及保存接口调用凭证,感兴趣的小伙伴们可以参考一下

  微信如何获取以及保存接口调用凭证,下面就为大家进行介绍
  
  一、说明
  
  *详细说明请参考前两篇文章。
  
  *本文分为三部分:
  
  接口调用凭证access_token的作用以及解释
  
  如何获取接口调用凭证access_token
  
  如何实现微信文档所说的“中控服务器”的实现以保存access_token
  
  * 本文结束会给出包括本文前三篇文章的所有演示源码
  
  为什么要获取和保存接口调用凭证access_token
  
  开始开发-获取接口调用凭据
  
  文档地址:http://mp.weixin.qq.com/wiki/14/ ... ba9b973f99a8ba.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-bi ... mp;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。
  
  实现
  1. private static final long MAX_TIME = 7200 * 1000;// 微信允许最长Access_token有效时间(ms)
  2. private static final String TAG = "WeixinApiTest";// TAG
  3. private static final String APPID = "wx889b****b3666b0b8";// APPID
  4. private static final String SECERT = "6da7676***f0a9f15fbf06027856bb";// 秘钥

  5. /*
  6. * 该测试用例演示了如何获取access_token。
  7. * access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token。
  8. */
  9. @Test
  10. public void getAccess_token() throws IOException {
  11.   // 拼接api要求的httpsurl链接
  12.   String urlString = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="
  13.       + APPID + "&secret=" + SECERT;
  14.   // 创建一个url
  15.   URL reqURL = new URL(urlString);
  16.   // 拿取链接
  17.   HttpsURLConnection httpsConn = (HttpsURLConnection) reqURL
  18.       .openConnection();
  19.   // 取得该连接的输入流,以读取响应内容
  20.   InputStreamReader isr = new InputStreamReader(
  21.       httpsConn.getInputStream());
  22.   // 读取服务器的响应内容并显示
  23.   char[] chars = new char[1024];
  24.   String reslut = "";
  25.   int len;
  26.   while ((len = isr.read(chars)) != -1) {
  27.     reslut += new String(chars, 0, len);
  28.   }
  29.   isr.close();
  30.   /*
  31.    * 转化json成javabean。引入了第三方jar:GSON
  32.    */
  33.   Gson gson = new Gson();// 将获取的json转化为java中的bean
  34.   // 注意:Access_token access_token是一个自己创建的javabean
  35.   Access_token access_token = gson.fromJson(reslut,
  36.       new Access_token().getClass());
  37.   if (access_token.getAccess_token() != null) {
  38.     System.out.println("获取的access_token是:"
  39.         + access_token.getAccess_token());
  40.     System.out.println("该access_token的有效时间是:"
  41.         + access_token.getExpires_in() + "s");
  42.   } else {
  43.     System.out.println(TAG + "获取access_token失败,请检查");

  44.   }

  45. }
复制代码

  保存接口调用凭证access_token
  
  思路
  
  将获取到的Access_token和当前时间存储到file里, 取出时判断当前时间和存储里面的记录的时间的时间差,如果大于MAX_TIME,重新获取,并且将获取到的存储到file替换原来的内容,如果小于MAX_TIME,直接获取。
  
  实现
  1. /*
  2.    * 该方法实现获取Access_token、保存并且只保存2小时Access_token。如果超过两个小时重新获取;如果没有超过两个小时,直接获取。该方法依赖
  3.    * :public static String getAccessToken();
  4.    *
  5.    * 思路:将获取到的Access_token和当前时间存储到file里,
  6.    * 取出时判断当前时间和存储里面的记录的时间的时间差,如果大于MAX_TIME,重新获取,并且将获取到的存储到file替换原来的内容
  7.    * ,如果小于MAX_TIME,直接获取。
  8.    */
  9.   @Test
  10.   public void getSavedAccess_token() throws IOException {
  11.     Gson gson = new Gson();
  12.     String mAccess_token = null;// 需要获取的Access_token;
  13.     File file = new File("temp_access_token.temp");// Access_token保存的位置
  14.     // 如果文件不存在,创建
  15.     if (!file.exists())
  16.       file.createNewFile();
  17.     // 如果文件大小等于0,说明第一次使用,存入Access_token
  18.     if (file.length() == 0) {
  19.       mAccess_token = getAccessToken();
  20.       FileOutputStream fos = new FileOutputStream(file, false);// 不允许追加
  21.       Access_token at = new Access_token();
  22.       at.setAccess_token(mAccess_token);
  23.       at.setExpires_in(System.currentTimeMillis() + "");
  24.       String json = gson.toJson(at);
  25.       fos.write((json).getBytes());
  26.       fos.close();
  27.     } else {
  28.       // 读取文件内容
  29.       FileInputStream fis = new FileInputStream(file);
  30.       byte[] b = new byte[2048];
  31.       int len = fis.read(b);
  32.       String mJsonAccess_token = new String(b, 0, len);// 读取到的文件内容
  33.       Access_token access_token = gson.fromJson(mJsonAccess_token,
  34.           new Access_token().getClass());
  35.       if (access_token.getExpires_in() != null) {
  36.         long saveTime = Long.parseLong(access_token.getExpires_in());
  37.         long nowTime = System.currentTimeMillis();
  38.         long remianTime = nowTime - saveTime;
  39.         // System.out.println(TAG + "时间差:" + remianTime);
  40.         if (remianTime < MAX_TIME) {
  41.           Access_token at = gson.fromJson(mJsonAccess_token,
  42.               new Access_token().getClass());
  43.           mAccess_token = at.getAccess_token();
  44.         } else {
  45.           mAccess_token = getAccessToken();
  46.           FileOutputStream fos = new FileOutputStream(file, false);// 不允许追加
  47.           Access_token at = new Access_token();
  48.           at.setAccess_token(mAccess_token);
  49.           at.setExpires_in(System.currentTimeMillis() + "");
  50.           String json = gson.toJson(at);
  51.           fos.write((json).getBytes());
  52.           fos.close();
  53.         }

  54.       }
  55.     }

  56.     System.out.println("获取到的Access_token是:" + mAccess_token);
  57.   }

  58.   /*
  59.    * 获取微信服务器AccessToken。该部分和getAccess_token() 一致,不再加注释
  60.    */
  61.   public static String getAccessToken() {
  62.     String urlString = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid="
  63.         + APPID + "&secret=" + SECERT;
  64.     String reslut = null;
  65.     try {
  66.       URL reqURL = new URL(urlString);
  67.       HttpsURLConnection httpsConn = (HttpsURLConnection) reqURL
  68.           .openConnection();
  69.       InputStreamReader isr = new InputStreamReader(
  70.           httpsConn.getInputStream());
  71.       char[] chars = new char[1024];
  72.       reslut = "";
  73.       int len;
  74.       while ((len = isr.read(chars)) != -1) {
  75.         reslut += new String(chars, 0, len);
  76.       }
  77.       isr.close();
  78.     } catch (IOException e) {

  79.       e.printStackTrace();
  80.     }
  81.     Gson gson = new Gson();
  82.     Access_token access_token = gson.fromJson(reslut,
  83.         new Access_token().getClass());
  84.     if (access_token.getAccess_token() != null) {
  85.       return access_token.getAccess_token();
  86.     } else {
  87.       return null;
  88.     }
  89.   }
复制代码

相关帖子

发表于 2017-1-17 17:18:16 来自手机 | 显示全部楼层
其实js如果遇到web安全类的项目,那就又要做牺牲了,无法读写文件,访问受限。。。哎。。。
点评 ( 1 ) 收起 / 展开点评

心如善水 2017年01月17日 22:08 详情 回复

学习

使用道具 举报

回复

发表于 2017-1-17 22:08:59 | 显示全部楼层
学习
点评 ( 1 ) 收起 / 展开点评

心如善水 2017年01月18日 13:54 详情 回复

学习

使用道具 举报

回复

发表于 2017-1-18 13:54:16 | 显示全部楼层
学习
使用道具 举报

回复

发表于 2017-1-21 22:47:10 来自手机 | 显示全部楼层
经常看到”西北的风“发帖,辛苦了
使用道具 举报

回复

发表于 2017-8-24 11:09:36 | 显示全部楼层
楼主分享得很棒棒,学习到了
使用道具 举报

回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于我们
联系我们
  • 电话:010-86393388
  • 邮件:udn@yonyou.com
  • 地址:北京市海淀区北清路68号
移动客户端下载
关注我们
  • 微信公众号:yonyouudn
  • 扫描右侧二维码关注我们
  • 专注企业互联网的技术社区
版权所有:用友网络科技股份有限公司82041 京ICP备05007539号-11 京公网网备安1101080209224 Powered by Discuz!
快速回复 返回列表 返回顶部