Nextjs服务端中存入cookie 全站使用然后跳转getServerSideProps

21 篇文章 1 订阅
"react": "^18",
"next": "13.5.4",
import { parse, serialize } from 'cookie';

export async function getServerSideProps(context:GetServerSidePropsContext) {
    const cookies = parse(context.req.headers.cookie || '');
    const authState = cookies['U_S'] || 0;

    const {query} = context;
    const {obj} = query;


    // const objString = JSON.stringify(obj);
    if (obj && typeof obj === 'string') {
        context.res.setHeader('Set-Cookie', [
            serialize('U_S', obj, {path: '/', maxAge: 30 * 24 * 60 * 60}),
            serialize('U_TOKEN', JSON.parse(obj).token, {path: '/', maxAge: 30 * 24 * 60 * 60}),
        ]);

        // 返回重定向到 /index 的信息
        return {
            redirect: {
                destination: '/',
                permanent: false,
            },
        };
    }


    try {
        const {get, post} = useRequest();
        const postData = {};
        const result = await post<{ code: string; data: any }>(P_PRODUCT_CATEGORY, postData);

        if (result.data.code === '00000') {
            const data = result.data.data;
            return {
                props: {
                    authStates: authState,
                    data,
                },
            };
        }
    } catch (error) {
        console.error('Error making POST request:', error);
    }

    return {
        props: {
            authStates: authState,
            data: [],
        },
    };
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Next.js ,你可以在服务端启动时执行一些脚本,可以使用 `server.js` 文件自定义服务器端逻辑。你可以在这个文件编写任意 Node.js 代码,例如: ```javascript const { createServer } = require('http') const next = require('next') const dev = process.env.NODE_ENV !== 'production' const app = next({ dev }) const handle = app.getRequestHandler() // 自定义服务端逻辑 console.log('服务端启动了') app.prepare().then(() => { createServer((req, res) => { handle(req, res) }).listen(3000, (err) => { if (err) throw err console.log('> Ready on http://localhost:3000') }) }) ``` 在上面的例子,我们在服务端启动时执行了一句打印输出,这就是一个自定义的服务端脚本。 如果你想要执行更多的服务端脚本,可以在 `createServer` 函数之前执行它们。例如: ```javascript const { createServer } = require('http') const next = require('next') const dev = process.env.NODE_ENV !== 'production' const app = next({ dev }) const handle = app.getRequestHandler() // 自定义服务端逻辑 console.log('执行服务端脚本...') // 执行更多的服务端脚本 require('./my-script.js')() app.prepare().then(() => { createServer((req, res) => { handle(req, res) }).listen(3000, (err) => { if (err) throw err console.log('> Ready on http://localhost:3000') }) }) ``` 在上面的例子,我们通过 `require('./my-script.js')()` 执行了一个名为 `my-script.js` 的脚本。你可以在这个脚本编写任意服务端代码。注意,这个脚本文件必须在服务端运行,不能在浏览器端运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值