前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Koa路由中获取上一页地址

Koa路由中获取上一页地址

作者头像
越陌度阡
发布2020-11-26 14:55:01
7950
发布2020-11-26 14:55:01
举报

在用Koa开发服务端时,经常会有这样一种业务场景,就是从不同的页面进入某一页,然后在返回时需要按原路返回,这个时候就需要记录上一页访问的路由地址,下面给大家介绍一个小技巧就可以实现这个要求。

实现的方法是在全局信息中定义一个变量,保存 ctx.request.headers['referer'],下面提供一个类似的Demo。

代码语言:javascript
复制
router.use(async (ctx, next) => {

    // 获取当前服务器的域名
    // console.log(ctx.request.header.host);

    // 给模板引擎配置全局全量
    ctx.state.__HOST__ = 'http://' + ctx.request.header.host;

    // 将含有参数的地址进行过滤(主要针对验证码地址),去除"/" 
    var pathname = url.parse(ctx.request.url).pathname.substring(1);

    var splitUrl = pathname.split('/');

    // 配置全局信息 
    ctx.state.G = {
        userinfo: ctx.session.userinfo,
        // 用于激活当前菜单
        url: splitUrl,
        // 上一页的地址
        prevPage:ctx.request.headers['referer']
    };

    // 如果有session
    if (ctx.session.userinfo) {
        await next();
    } else {
        // 如果是请求登录页 或是 提交登录 或是 获取验证码 页面
        if (pathname == 'admin/login' || pathname == 'admin/login/doLogin' || pathname == 'admin/login/code') {
            await next();
        } else {
            ctx.redirect('/admin/login');
        }
    }
});
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/09/26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
验证码
腾讯云新一代行为验证码(Captcha),基于十道安全栅栏, 为网页、App、小程序开发者打造立体、全面的人机验证。最大程度保护注册登录、活动秒杀、点赞发帖、数据保护等各大场景下业务安全的同时,提供更精细化的用户体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档