全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

微信小程序之页面拦截器的示例代码

场景

  • 小程序有52个页面,其中13个页面无需任何身份,另外39个页面需要系统角色。对于这39个页面,如果微信用户没有系统角色,则跳转到登录页。
  • 是否有系统角色信息需要通过异步请求来获取。

需求分析&实现

对需求进行抽象,其实要的就是一个过滤器,对小程序页面的访问进行过滤,符合条件的通过,不符合条件进行其他处理。

使用过php的laravel框架的童鞋,肯定一下子就联想到了laravel框架的http中间件:

HTTP 中间件提供一个方便的机制来过滤进入应用程序的 HTTP 请求,例如,Laravel 默认包含了一个中间件来检验用户身份验证,如果用户没有经过身份验证,中间件会将用户导向登录页面,然而,如果用户通过身份验证,中间件将会允许这个请求进一步继续前进。当然,除了身份验证之外,中间件也可以被用来执行各式各样的任务,CORS 中间件负责替所有即将离开程序的响应加入适当的响应头,一个日志中间件可以记录所有传入应用程序的请求。

令人忧桑的是,微信小程序并没有提供针对Page实例的中间件机制。所以只能从Page实例的生命周期处下手。

对于onLoad,一个页面只会调用一次;对于onShow,每次打开页面(比如小程序从后台转到前台)都会调用一次。

在onLoad或者onShow钩子函数里,对用户身份进行校验,通过后则拉取该页面需要的数据,否则跳转到登录页。

//orderDetail.js
onShow: function () {
  let that = this;
  //身份校验
  service.identityCheck(() => {
     //跳转到登录页
     wx.redirectTo({
      url: "/pages/common/login/login"
     });
    }, () => {  
     //获取页面数据等等   
     that.getDetail(this.orderId);
     ...
    }
  );
 },

不过,每个页面都要这样写,重复代码好多啊,侵入性也强。不如用装饰函数(高大上的说法是装饰者模式)来包装一下:

//filter.js
function identityFilter(pageObj){
  if(pageObj.onShow){
    let _onShow = pageObj.onShow;
    pageObj.onShow = function(){
      service.identityCheck(()=>{
        //跳转到登录页
        wx.redirectTo({
          url: "/pages/common/login/login"
        });
      },()=>{
        //获取页面实例,防止this劫持
        let currentInstance = getPageInstance();
        _onShow.call(currentInstance);
      });
    }
  }
  return pageObj;
}

function getPageInstance(){
  var pages = getCurrentPages();
  return pages[pages.length - 1];
}

exports.identityFilter = identityFilter;

filter.js用以提供过滤器方法,除了现有的用户身份拦截,后续如果需要其他拦截,可以在这个文件增加。然后,在需要用户身份拦截的小程序页面代码里,用filter.identityFilter处理一下就可以了:

//orderDetail.js
let filter = require('filter.js');
Page(filter.identityFilter({
  ...
  onShow: function () {
    //获取页面数据等等
    this.getDetail(this.orderId);
    //...
  },
  ...
}));

使用Promise进行优化

上面的实现中,每次访问页面,都会执行一次获取用户身份的方法(就是上面代码里的service. identityCheck )。其实没有必要,在小程序启动的时候获取一次就行了。也就是说,放在app.js的onLaunch方法里执行。

每个小程序页面实例化时,一般也会执行异步方法,用来获取页面需要的数据。关键在于,我们需要保证,页面的异步方法 必须在 获取用户身份的异步请求 之后执行。

毋容置疑,Promise最擅长处理异步请求的执行顺序了。主子,快放代码粗来:

//app.js
App({
  onLaunch:function(){
    let p = new Promise(function(resolve,reject){
      service.identityCheck(resolve,reject);
    });
    this.globalData.promise = p; 
  },
  ...
  globalData: {
    promise:null,
  }  
});
//filter.js
const appData = getApp().globalData;
function identityFilter(pageObj){
  if(pageObj.onShow){
    let _onShow = pageObj.onShow;
    pageObj.onShow = function(){
      //改动点
      appData.promise.then(()=>{
        //跳转到登录页
        wx.redirectTo({
          url: "/pages/common/login/login"
        });
      },()=>{
        //获取页面实例,防止this劫持
        let currentInstance = getPageInstance();
        _onShow.call(currentInstance);
      });
    }
  }
  return pageObj;
}

小结

基本实现了小程序页面的用户身份拦截器,但是比起laravel的http中间件还是逊色一些:

  • 需要对每个页面代码包装一层。
  • 即使用户身份校验不通过,小程序也并不会阻塞页面的渲染。假如获取用户身份的异步方法一分钟才执行完,小程序页面还是会展示出来,一分钟之后才跳转到登录页。需要自己增加逻辑,比如在这一分钟内,页面展示空白内容。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# 微信小程序页面拦截器  # 微信小程序拦截器  # 微信小程序网络请求模块封装的具体实现  # 微信小程序中网络请求缓存的解决方法  # 微信小程序网络请求实现过程解析  # 微信小程序中如何使用flyio封装网络请求  # 封装微信小程序http拦截器过程解析  # 微信小程序wx.request拦截器使用详解  # 微信小程序封装网络请求和拦截器实战步骤  # 跳转到  # 身份验证  # 应用程序  # 的是  # 放在  # 也会  # 在这个  # 都要  # 将会  # 在这  # 转到  # 只会  # 不符合  # 提供一个  # 会将  # 后才  # 使用过  # 各式各样  # 关键在于  # 符合条件 


相关文章: 湖南网站制作公司,湖南上善若水科技有限公司做什么的?  小程序网站制作需要准备什么资料,如何制作小程序?  建站之星安装路径如何正确选择及配置?  建站org新手必看:2024最新搭建流程与模板选择技巧  移民网站制作流程,怎么看加拿大移民官网?  官网建站费用明细查询_企业建站套餐价格及收费标准指南  建站主机助手选型指南:2025年热门推荐与高效部署技巧  个人摄影网站制作流程,摄影爱好者都去什么网站?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  建设网站制作价格,怎样建立自己的公司网站?  如何用好域名打造高点击率的自主建站?  建站之星伪静态规则如何正确配置?  如何通过NAT技术实现内网高效建站?  如何用5美元大硬盘VPS安全高效搭建个人网站?  如何快速搭建安全的FTP站点?  C#如何在一个XML文件中查找并替换文本内容  C++如何使用std::optional?(处理可选值)  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  建站之星安装模板失败:服务器环境不兼容?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  如何快速搭建支持数据库操作的智能建站平台?  如何通过.red域名打造高辨识度品牌网站?  如何在IIS7中新建站点?详细步骤解析  如何在阿里云通过域名搭建网站?  红河网站制作公司,红河事业单位身份证如何上传?  网站网页制作专业公司,怎样制作自己的网页?  昆明网站制作哪家好,昆明公租房申请网上登录入口?  建站之星如何助力企业快速打造五合一网站?  如何配置WinSCP新建站点的密钥验证步骤?  智能起名网站制作软件有哪些,制作logo的软件?  ,石家庄四十八中学官网?  建站之星好吗?新手能否轻松上手建站?  如何确保西部建站助手FTP传输的安全性?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  高端建站如何打造兼具美学与转化的品牌官网?  如何制作算命网站,怎么注册算命网站?  如何快速生成高效建站系统源代码?  如何快速上传建站程序避免常见错误?  大连 网站制作,大连天途有线官网?  定制建站策划方案_专业建站与网站建设方案一站式指南  网站制作话术技巧,网站推广做的好怎么话术?  如何在Ubuntu系统下快速搭建WordPress个人网站?  如何在万网主机上快速搭建网站?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  如何通过宝塔面板实现本地网站访问?  建站上传速度慢?如何优化加速网站加载效率?  威客平台建站流程解析:高效搭建教程与设计优化方案 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。