uniapp 实现简易的token认证机制的request框架

uniapp 实现简易的token认证机制的request框架

由于在发送http请求的时候需要验证token。登陆后我们需要把Authorization字段的值放到header里面。目的是需要有统一处理的地方。

  1. 微信中的认证流程的时序图
image
  1. 需要基于 uni.request(options) 做一次封装

    import config from './config'
    
    class HttpRequest {
      constructor() {
        console.log('HttpRequest');
      }
    
      request(options) {
        options.url = config.baseUrl + options.url;
        try {
          const token = uni.getStorageSync('token');
          if (token) {
            options.header = {
              'Authorization' : token
            };
          }
        } catch (err) {
          console.log(err)
        }
        return uni.request(options);
      }
    }
    
    export default new HttpRequest;
    
  2. 在登陆接口中处理token

    import http from './base.request.js'
    
    export const login = (code) => {
      return http.request({
        url: '/user/wx/login',
        data: {
          js_code: code
        }
      }).then(function(data) {
        let [error, res] = data;
        if (error) {
          return Promise.reject(error);
        }
        let token = res.data.wx.openid;
        console.log(token);
        try {
          uni.setStorageSync('token', token);
        } catch (e) {
          //TODO handle the exception
        }
        return Promise.resolve(data);
      });
    }
    
  3. 其他模块的请求按照现有模式进行

    import http from './base.request.js'
    
    export const getCrabList = () => {
      return http.request({
        url: '/craps/product/list'
      })
    }
    
  4. 未完待续,

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容