如何解决根据 Next.js next.config.js 中的标头或 cookie 重定向
我们正在使用 Next.js 并希望根据浏览器 Accept-Language
标头将所有路径(不仅仅是 root)路由到基于区域设置的路径。但是,如果用户设置了他们的区域,我们将设置一个 cookie,需要首先检查该 cookie 以尊重用户的偏好。
因此我们需要检查 cookie,如果没有,请尝试根据浏览器语言标头进行重定向。我们使用的 ISG 仅限于 next.config.js 重定向服务器端。
根据文档,这应该可行,但由于我们使用的是 ISG,我们需要在 next.config.js
重定向函数中执行此操作。
我们已经尝试过这个解决方案,但它不起作用(我们得到无限重定向,因为 cookie 和标头都匹配):
const { i18n } = require('./next-i18next.config');
const withTM = require('next-transpile-modules')(['fitty','react-svg']); // pass the modules you would like to see transpiled
const handleLocaleRedirects = (path) => {
const result = [];
i18n.locales.forEach((locale) => {
i18n.locales.forEach((loc) => {
if (loc !== locale) {
result.push({
source: `/${locale}${path}`,has: [
{
type: 'header',key: 'accept-language',value: `^${loc}(.*)`,},],permanent: false,locale: false,destination: `/${loc}${path}`,});
result.push({
source: `/${locale}${path}`,has: [
{
type: 'cookie',key: 'NEXT_LOCALE',value: loc,permanent: true,});
}
});
});
return result;
};
module.exports = withTM({
i18n,reactStrictMode: true,images: {
domains: [
'dxjnh2froe2ec.cloudfront.net','starsona-stb-usea1.s3.amazonaws.com',eslint: {
// Warning: Dangerously allow production builds to successfully complete even if
// your project has ESLint errors.
ignoreDuringBuilds: true,async redirects() {
return [...handleLocaleRedirects('/:celebrityId')];
},});
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。