Heim  >  Fragen und Antworten  >  Hauptteil

Warum wird die Next.js-Middleware mehrmals ausgeführt?

Ich verwende die Datei npx create-next-app@latest --typescript 创建了一个新的 Next.js。安装后(版本为13.3.4),在不更改任何文件的情况下,我在src文件夹内添加了一个新的middleware.ts und habe einfach diesen Code eingegeben:

import type { NextRequest } from "next/server";
import { NextResponse } from "next/server";

export function middleware(request: NextRequest) {
  console.log("request", request.nextUrl.pathname);
  return NextResponse.next();
}

// EDIT: By putting this block will get expected result.
export const config = {
  matcher: [
    /*
     * Match all request paths except for the ones starting with:
     * - api (API routes)
     * - _next/static (static files)
     * - _next/image (image optimization files)
     * - favicon.ico (favicon file)
     */
    '/((?!api|_next/static|_next/image|favicon.ico).*)',
  ],
};

Konsolenprotokoll wird mehrmals aufgerufen. Ich glaube, es war einmal? Muss ich für diese neue Next.js-Installation irgendwelche Konfigurationen vornehmen?

Hinweis: Ich werde zur Authentifizierung eine Cookie-Logik in der Middleware ausführen. Screenshot:

P粉448346289P粉448346289312 Tage vor427

Antworte allen(1)Ich werde antworten

  • P粉950128819

    P粉9501288192024-01-05 09:12:41

    这是正常现象,因为中间件默认会针对每个请求运行,包括用于获取 JavaScritp、CSS 和图像文件等资源的请求。正如您可以在 doc 中阅读的那样:

    如果您记录request.nextUrl.pathname,您将看到它运行的不同路径。要让它仅对某些路径执行,您需要使用条件语句matcher 对象,如下所示:

    import type { NextRequest } from "next/server";
    import { NextResponse } from "next/server";
    
    export function middleware(request: NextRequest) {
      console.log("request", JSON.stringify(request));
      return NextResponse.next();
    }
    
    // The above middleware would only run for the "/" path
    export const config = {
      matcher: '/',
    }

    Antwort
    0
  • StornierenAntwort