nextjs通过使用getServerSideProps实现登录后跳转上一页

在实际开发中,经常遇到登录后跳转到之前的页面,可使用getServerSideProps实现该功能,getServerSideProps 是 next.js 中的一项特色功能,可以让我们在给页面设置一些初始的 props 参数。

getServerSideProps 是定义在页面中的 API,但是其执行环境是 node 端,而不是客户端,一般常见使用场景为:

  • 页面前置权限校验
  • 页面必备参数获取

使用时需要在对应的 page 文件中 export getServerSideProps

复制代码
const Page = props => {
// 登录
  const login = async () => {
    const data = {
      account: mobile ? mobile : email,
      password: pwd,
      clientType: 2,  //客户端类型
      AreaCode: '+' + areaCode,
      ClientMark: guid(),
      Ip: ip
    }
    const re = /^\w+@[a-z0-9]+\.[a-z]{2,4}$/
    const myreg = /^\d+(.\d{1,2})?$/
    if (index == 1) {
      if (areaCode == '') {
        Toast.show({ content: lang['请选择国家'] })
        return
      }
      if (!myreg.test(mobile)) {
        Toast.show({ content: lang['手机号码输入错误'] })
        return
      }
    } else if (index == 2) {
      // if (!re.test(email)) {
      //   Toast.show({ content: lang['电子邮箱输入错误'] })
      //   return
      // }
    }
    const rep = await props.user.login(data)
    if (!rep.success) {
      Toast.show({ content: rep.error.message })
    } else {
      setToken(rep.result.token)
      setAreaCodeLang(areaCode)
      props.user.token = rep.result.token
      getUserInfo()
      setTimeout(() => {
        props.ws.reconnect()
        if (props.prevPageHeader.referer && pathname != '/login' ) {
          back()
        } else {
          push('/user')
        }
      }, 1000);
    }
  }
    return <div>page</div>;
};
export async function getServerSideProps(context) {
    return {
        props: {
        	prevPageHeader: context.req.headers,
        }
    };
}
export default Page;

这样便可以从页面组件中直接使用 props 来获取 getServerSideProps 注入的 props 了。上述代码就把context.req.headers注入了props中,可以通过context.req.headers中的referer获取到上一个页面的路由地址,从而实现登录后跳转到上一页。

注意:

  • 直接在地址栏中输入地址进行跳转的context.req.headers.referer会没有值。
  • 有些特殊页面,例如登录页登录的,上一页为登录页,所以不需要跳转到上一页,可以通过pathname ,判断是否是这些特殊页面而不进行跳转
  • getServerSideProps 只能在页面组件中使用,在其他子组件中是不能使用的。
  • 通过npm run export 打包发布的项目不能使用getServerSideProps

与 getStaticProps 只在build时生成一遍静态页面,或者定期重新生成页面不同,使用getServerSideProps,页面在每接收到一条传入请求就重新生成一遍。

因为每次请求都是从数据库读数据重新生成页面,页面加载速度会变慢。但是使用getServerSideProps 可以访问 request 对象。

如果页面不是需要每秒更新几次,或者需要访问 request 对象,那么使用getStaticProps 函数更好。
next官网 getServerSideProps的参数信息

或者参考:https://www.geeksforgeeks.org/next-js-getserversideprops-function/

相关推荐
子兮曰1 小时前
后端字段又改了?我撸了一个 BFF 数据适配器,从此再也不怕接口“屎山”!
前端·javascript·架构
万少3 小时前
使用Trae轻松安装openclaw的教程-附带免费token
前端·openai·ai编程
颜酱3 小时前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
浪浪山_大橙子3 小时前
OpenClaw 十分钟快速,安装与接入完全指南 - 推荐使用trae 官方 skills 安装
前端·人工智能
忆江南3 小时前
iOS 可视化埋点与无痕埋点详解
前端
离开地球表面_993 小时前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试
_柳青杨3 小时前
跨域获取 iframe 选中文本?自己写个代理中间层,再也不求后端!
前端
比尔盖茨的大脑3 小时前
事件循环底层原理:从 V8 引擎到浏览器实现
前端·javascript·面试
天才熊猫君3 小时前
Vue3 命令式弹窗原理和 provide/inject 隔离机制详解
前端
bluceli3 小时前
Vue 3 Composition API深度解析:构建可复用逻辑的终极方案
前端·vue.js