Koa路由中获取上一页地址

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/weixin_40629244/article/details/101482498

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

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

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');
        }
    }
});

猜你喜欢

转载自blog.csdn.net/weixin_40629244/article/details/101482498