网上查了一圈,没发现有人分享,一路吃坑吃过来,终于实现了自动刷新 token 并重发请求的拦截器。

然后就想着分享一下,也许分享出来可以帮助小伙伴快速实现自己的token刷新机制,关于Dio的拦截器,不过多介绍,直接前往 Dio 的文档,即可找到拦截器的介绍。我只说一下使用上需要注意的点,以及我写的代码。不多,也就70行。

拦截器文档传送门:Dio中文文档

阅读全文 »

一开始想过用子线程来实现,还好搜索了一下,发现 Android 自带了一个倒计时类,正好适合,这个类就是CountDownTimer,创建它需要提供两个参数,一个是总计时时间(单位是毫秒),一个是步长,也就是一次走多少毫秒.然后还需要实现它的两个接口.

  1. void onTick(long millisUntilFinished)
    当时间每走一次就会调用这个方法,参数是还剩下多少时间没走,在这里禁用按钮,然后显示还剩多少时间
  2. void onFinish()
    这个一看就知道是倒计时完成了,会回调它,可以在这里启用按钮

上示例代码

//倒计时60秒,这里不直接写60000,而用1000*60是因为后者看起来更直观,每走一步是1000毫秒也就是1秒
CountDownTimer timer = new CountDownTimer(1000 * 60, 1000) {
    @SuppressLint("DefaultLocale")
    @Override
    public void onTick(long millisUntilFinished) {
        button.setEnabled(false);
        button.setText(String.format("已发送(%d)",millisUntilFinished/1000));
    }

    @Override
    public void onFinish() {
        button.setEnabled(true);
        button.setText("重新获取");
    }
};
timer.start();

最后一定要记得 start()

在渲染订单列表的时候,用到了三层recyclerView嵌套,结果进入订单列表页,当最里层的数据一个屏幕装不下的时候,就会把外层的view挤出去.比如店铺名.后来查各种资料发现是焦点问题:
当新出现一个recyclerView的时候,这个recyclerView就会获得焦点,它的第一条数据就会出现在屏幕顶部,解决方案是:

<LinearLayout
   android:orientation="vertical"
   android:layout_width="match_parent"
   android:layout_height="wrap_content">

   <View
       android:focusable="true"
       android:focusableInTouchMode="true"
       android:layout_width="match_parent"
       android:layout_height="4dp"/>

   <android.support.v7.widget.RecyclerView
       android:id="@+id/rv_goods_cart"
       android:layout_width="match_parent"
       android:layout_height="match_parent" />
</LinearLayout>

在最外层的RecyclerView前面新建一个View,然后给他焦点,这样的话,进入订单页初次渲染的时候,最外层的recyclerView就不会被挤出去了.

之前用过 APP 写日记,也用过 OneNote 写日记,APP 有数据丢失的风险,OneNote 的书写和查看体验太差了...而且数据不在自己手里始终不安心,那天要是想转移到其他地方也麻烦.

遂想着这个 Typecho 用来写日记貌似不错,颜值高,可定制性高,数据库随时可以备份,转移.甚至可以自己开发个APP,然后把数据挪过去...

但是写的日记有可能被别人看到之类的,如果把日记设置成私密的话,又太麻烦了,控制台的概览也统计不了私密文章,不如让别人都进不来把,于是找资料开发了这个简单的插件,只有登陆的用户才能访问网站.没登陆的状态下访问网站会自动跳转到登陆页面.当然,注册功能我是关闭了的

不知道有没有人会需要,总之先分享好了.

点击下载插件(百度云)