为微信小程序端添加一个session机制。

158 阅读1分钟
原文链接: nai8.me

我们做后台用户认证的时候一般会借助于session机制,非常方便,今天我们使用小程序的Storage机制自己实现一个session。

本文思路来自于前几日对微信wafer的源码阅读,感谢wafer所有代码编写者。

我们先来看代码实现

var SESSION_KEY = 'xxxxxx';

var Session = {
    get: function() {
        return wx.getStorageSync(SESSION_KEY) || null;
    },

    set: function(session) {
        wx.setStorageSync(SESSION_KEY, session);
    },

    clear: function() {
        wx.removeStorageSync(SESSION_KEY);
    },
};

module.exports = Session;

很简单是不是,这样就实现了,解释下,比如当我们做登录的时候,需要在小程序端做一个存储,主要存放的是后端返回来的access_token(此值用于需要用户认证的接口请求),那么就可以使用上面Session。

if (result.statusCode === 200 && data.access_token) {
    Session.set(data.access_token);    
}

当我们判断本地用户是否处于登录态的时候也可以进行如下操作

var session = Session.get();
if (session) {
    wx.checkSession({
        success: function () {
            ////
        },

        fail: function () {
            Session.clear();
            // doLogin();
        },
    });
} else {
    //doLogin(); 进行登录
}

当然这个机制不是必须的,但是有了它之后让代码变的更加简洁,获得用户的会话、写入会话以及清空会话,有一点你的后端小师弟看到你的代码的时候,也会非常轻松看懂。