zoukankan      html  css  js  c++  java
  • 微信公众号号开发小记(六)使用开源框架开发

    到了现在,必须要正视一个问题了,之前所作的都是不推荐的,为什么,因为你没发现之前咱们还在调用官方API接口吗?还在写程序去获取token机械json数据呢?而且json数据咱们还要自己拼接,这可是不行的,要知道在实际的开发中,是奔着以最快时间达成目标为主要的,所以,怎么办?

    使用开源框架啊,现如今,做微信公众号开发这块也是比较成熟的,也有一些比较好的开源框架,可以说,使用了开源框架之后,很多事情基本上一行代码搞定。

    我这里使用的开源框架是—Wx-tools

    GitHub地址:https://github.com/antgan/wx-tools

    技术文档地址:https://www.w3cschool.cn/wxtools/

    这个开源库给的文档还是相当详细的,可以看一下文档目录

    所以基本上看着文档就能实现大多数功能,这里真的要感谢这位开源作者了,偷偷告诉你,这位开源作者跟我一样年龄,唉,惭愧啊,不过人家工作早,赞!自己要加油了!

    这里简单说一下用法,首先导入项目依赖

    <!--wx-tools-->
        <dependency>
          <groupId>com.soecode.wx-tools</groupId>
          <artifactId>wx-tools</artifactId>
          <version>2.1.4-RELEASE</version>
        </dependency>

    这里还要依赖一些其他的包,这里一并给出

     <!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
        <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-api</artifactId>
          <version>1.7.25</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/ch.qos.logback/logback-classic -->
        <dependency>
          <groupId>ch.qos.logback</groupId>
          <artifactId>logback-classic</artifactId>
          <version>1.2.3</version>
          <scope>test</scope>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpclient -->
        <dependency>
          <groupId>org.apache.httpcomponents</groupId>
          <artifactId>httpclient</artifactId>
          <version>4.5.3</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.httpcomponents/httpmime -->
        <dependency>
          <groupId>org.apache.httpcomponents</groupId>
          <artifactId>httpmime</artifactId>
          <version>4.5.3</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.codehaus.jackson/jackson-mapper-asl -->
        <dependency>
          <groupId>org.codehaus.jackson</groupId>
          <artifactId>jackson-mapper-asl</artifactId>
          <version>1.9.13</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.thoughtworks.xstream/xstream -->
        <dependency>
          <groupId>com.thoughtworks.xstream</groupId>
          <artifactId>xstream</artifactId>
          <version>1.4.10</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
        <dependency>
          <groupId>commons-io</groupId>
          <artifactId>commons-io</artifactId>
          <version>2.4</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 -->
        <dependency>
          <groupId>org.apache.commons</groupId>
          <artifactId>commons-lang3</artifactId>
          <version>3.7</version>
        </dependency>

    导入以上maven依赖之后就可以开心使用这个开源框架了。

    服务器验证

    首先从最开始的服务器验证这块,对于wx-tools这个框架,总的接口就是IService,而我们要使用的则是它的实现类WxService,很多功能都是通过它调用的,比如我们进行服务器签名验证

    这里使用开源框架来替换我们之前写的工具类,记得这里多了一个参数,看,现在使用开源框架我们一行代码就可以搞定服务器验证,而不使用框架的话我们就得自己实现验证的工具类了。

    解决token调取上限问题

    其实在之前的操作中一直隐藏着一个很大的问题,那就是AccessToken的问题,因为调用任何接口基本上都要用到AccessToken,但是每调用一次产生的AccessToken两小时后自动失效,就要重新调用,也许你会说,两个小时足够了啊,可是我们进行本地调试的时候,免不了重启服务器,这样AccessToken就会被刷新,所以很可能会出现一个AccessToken调取达到上限的问题,因为AccessToken的调用每天是有限制的,所以,这里对AccessToken采用硬编码。

    也就是将调取得到的AccessToken进行硬编码,等到两个小时之后再次获取,使用框架获取AccessToken是这样的

    String accessToken = iService.getAccessToken();

    所以我这里新建一个MyWxService去继承WxService

    /**
     * 继承自WxService以便修改响应方法
     * 比如对token的存储
     */
    public class MyWxService extends WxService {
        @Override
        public String getAccessToken() throws WxErrorException {
            /**
             * token每天调取上限位2000次
             * 为避免达到上限
             * 将获得的token以硬编码方式存储
             * 一个token的使用时长有两个小时左右
             */
            //开发测试采用,两小时过后需要调用上线采用的方法刷新获取新的token
            return "12_2sztWZDG-06oyyQ5ObBFwW1TiN3LibX7nJ1FCoxLfVpj0TOdu0YLfwQHpCvZTIgi0mavu0B9D0wPQ3DA98e2lTGTB0gQLWHftgVLk1WnKcHCeSgDluza-tUzYKxxZqWDLImTwcjg1bnuy9yqCYAbACAUQS";
    
            //正常上线采用
    //        return super.getAccessToken();
        }
    }

    需要获取AccessToken的话就是用新创建的MyWxService调用,也就是这样

    IService iService = new MyWxService();
    String accessToken = iService.getAccessToken();

    如此一来就可以解决AccessToken调取上限问题。使用了框架之后对于公众号的具体业务开发,比如接收消息,响应消息或者用户管理等都变得非常简单了,剩下的就是看你的具体需求了。

    根据你的需求,查看wx-tools的技术文档,实现具体的业务逻辑,就是你接下来要做的事了,本来想再举几个wx-tools的使用例子,可是人家的文档上已经写的很详细,所以就没必要再写了。

    所以嘞,仔细看文档,仔细看文档,仔细看文档!!!

  • 相关阅读:
    5.模拟线程切换
    3.KPCR
    Java概述--Java开发实战经典
    java中设置虚拟机最大内存
    java static代码段
    原码、反码、补码的理解
    使用jmatio读写matlab数据文件
    matlab常用函数
    java的classpath和path理解
    读取SequenceFile中自定义Writable类型值
  • 原文地址:https://www.cnblogs.com/ithuangqing/p/12113658.html
Copyright © 2011-2022 走看看