Переписывает на основе user-agent в nextjs

У меня есть мультидоменный сайт в NextJs. Я хочу получать данные в зависимости от домена и типа устройства. Теперь я могу распознать домен, но я хочу, чтобы пользовательский агент переписывал правила и использовал его в функции getStaticProps. Вот мои правила в файле next.config.js.

      async rewrites() {
    return {
        afterFiles: [
            {
                has: [
                    {
                        type: 'host',
                        value: '(?<host>.*)',
                    },
                    {
                        type: 'header',
                        key: 'User-Agent',
                        value: '(?<ua>.*)',
                    },
                ],
                source: '/',
                destination: '/organizations/:host?ua=:ua',
            },
        ],
    };
},

Вы знаете, как поймать user-agent при переписывании? или у вас есть другое решение? Я хочу распознавать типы устройств (мобильные, планшетные или настольные) и отображать различные модели DOM на их основе.

1 ответ

Я решил эту проблему с помощью функции промежуточного программного обеспечения NextJs. https://nextjs.org/docs/advanced-features/middleware

      import { NextRequest, NextResponse } from 'next/server';
import parser from 'ua-parser-js';

// RegExp for public files
const PUBLIC_FILE = /\.(.*)$/;

export async function middleware(req: NextRequest) {
    / Clone the URL
    const url = req.nextUrl.clone();

    // Skip public files
    if (PUBLIC_FILE.test(url.pathname)) return;

    const ua = parser(req.headers.get('user-agent')!);
    const viewport = ua.device.type === 'mobile' ? 'mobile' : 'desktop';

    url.pathname = `/${viewport}/${req.headers.get('host')}${url.pathname}`;


    return NextResponse.rewrite(url);
}
Другие вопросы по тегам