Is there a way to exclude specific path from running on middleware?
Answered
Nile Crocodile posted this in #help-forum
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
Nile CrocodileOP
Is there a way to exclude specific path like "/about/" or "careers" from running middleware.
This is code i am using right now but it seems, this will exclude all paths starting with "about".
So it will exclude "about-test" also, which is something i don't want?
export const config = {
matcher: [
"/((?!about|careers|contact-us|api|_next/static|_next/image|favicon.ico|robots.txt|manifest.json|browserconfig.xml).*)",
],
};
This is code i am using right now but it seems, this will exclude all paths starting with "about".
So it will exclude "about-test" also, which is something i don't want?
export const config = {
matcher: [
"/((?!about|careers|contact-us|api|_next/static|_next/image|favicon.ico|robots.txt|manifest.json|browserconfig.xml).*)",
],
};
Answered by iyxan23
hi, this is a workaround i had just figured out, looks kinda clunky but it works 😄
data:image/s3,"s3://crabby-images/08363/08363ea2cd77fe6d239f96ebbe954fb7b66f3da5" alt="Image"
15 Replies
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt="Avatar"
Asian black bear
If you don't want to mess with the matcher just check for the path in the middleware and early return using
next()
in theredata:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
@Nile Crocodile Is there a way to exclude specific path like "/about/" or "careers" from running middleware.
This is code i am using right now but it seems, this will exclude all paths starting with "about".
So it will exclude "about-test" also, which is something i don't want?
export const config = {
matcher: [
"/((?!about|careers|contact-us|api|_next/static|_next/image|favicon.ico|robots.txt|manifest.json|browserconfig.xml).*)",
],
};
data:image/s3,"s3://crabby-images/2b939/2b939700dff295ec26f3abeaf794b4ea46777489" alt="Avatar"
u can do this
export const config = {
matcher: [
"/((?!^/about/$|^/careers$|^/contact-us$|^/api|^/_next/static|^/_next/image|^/favicon.ico|^/robots.txt|^/manifest.json|^/browserconfig.xml).*)",
],
};
data:image/s3,"s3://crabby-images/de0af/de0af7f804d9b8d38962e423a18264e0a1dc003d" alt="Image"
data:image/s3,"s3://crabby-images/7d993/7d993971ecdc66d18f9a65a116e22a5c8002a05b" alt="Avatar"
i honestly think it would be more intuitive if the next team, instead of using a single regex, used glob matching on a list instead. imagine doing
{ exclude: ["/careers/*", "/about/*"] }
, that'd be pretty awesome :)data:image/s3,"s3://crabby-images/7d993/7d993971ecdc66d18f9a65a116e22a5c8002a05b" alt="Avatar"
@iyxan23 hi, this is a workaround i had just figured out, looks kinda clunky but it works 😄
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
Nile CrocodileOP
Testing this returned and error
/((?!about(/|w|$)|^api|_next/static|_next/image|favicon.ico|robots.txt|manifest.json|browserconfig.xml).*)
https://nextjs.org/docs/messages/invalid-route-sourcedata:image/s3,"s3://crabby-images/7d993/7d993971ecdc66d18f9a65a116e22a5c8002a05b" alt="Avatar"
seems like you're missing a backslash
\
on the w
therebut huh that's odd, even if it was a regular w, it should've been able to be parsed
might want to try gin's regex to see if that works
data:image/s3,"s3://crabby-images/449ea/449eabbae27543cbc9fbb7cd559cf4dc1630cbe2" alt="Avatar"
let requestedPath = request.nextUrl.pathname;
//No authentication needed for route
if (mw_IsNoAuthRoute(requestedPath) == true) {
return NextResponse.next();
}
To @Asian black bear point, this is how I do it.
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt="Avatar"
@Asian black bear If you don't want to mess with the matcher just check for the path in the middleware and early return using `next()` in there
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
Nile CrocodileOP
This would still be logged as invocation of middleware. Right? I can still see that path being logged for triggering middleware even when using something like:
if (request.nextUrl.pathname === "/about/") {
return NextResponse.next();
}
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt="Avatar"
Asian black bear
Yes, but it really doesn't matter.
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
Nile CrocodileOP
yeah, just wanted to to check
@Asian black bear Idea is i guess that it would just not run any function but go further to that path.