当前位置: 首页 > news >正文

阿里巴巴吧网站建设企业标志设计公司

阿里巴巴吧网站建设,企业标志设计公司,建筑工程网络进度计划备注填写范例,培训学校网站模板概述 Next.js 的 中间件 (Middleware) 是一种在请求完成之前运行的函数,用于对入站请求进行处理和操作。它可以在路由匹配前执行逻辑,用于身份验证、请求重写、重定向、设置响应头等任务。 使用场景 身份验证:在用户访问页面前检查登录状态…

概述

Next.js 的 中间件 (Middleware) 是一种在请求完成之前运行的函数,用于对入站请求进行处理和操作。它可以在路由匹配前执行逻辑,用于身份验证、请求重写、重定向、设置响应头等任务。


使用场景

  • 身份验证:在用户访问页面前检查登录状态。
  • 国际化处理:根据用户的语言偏好设置动态重定向。
  • A/B 测试:动态分流用户到不同的页面。
  • IP 限制:根据访问者 IP 地址限制访问。

中间件基本使用

1. 创建 middleware.ts

中间件文件位于项目根目录(如果有 src 则为 src 下 )下的 middleware.ts

import { NextResponse } from 'next/server';
import type { NextRequest } from 'next/server';export function middleware(request: NextRequest) {const { pathname } = request.nextUrl;// 示例:阻止访问 `/admin` 路径if (pathname.startsWith('/admin')) {return NextResponse.redirect(new URL('/login', request.url));}// 默认返回请求return NextResponse.next();
}

rewrite 重写是页面的重写,比如将 /admin 页面重写内容为 /user 页面,而我们的路由还是 /admin。重定向是改写路由,比如将 /admin 重定向到 /user ,那么我们直接访问的就是 /user 。

2. 匹配特定路由

通过 matcher 来指定中间件生效的路径。

export const config = {matcher: ['/admin/:path*', '/api/:path*'], // 匹配 /admin 和 /api 路径
};

详细示例

示例 1:基于身份验证的访问控制

假设我们有一个 /admin 页面,只有登录用户可以访问。

中间件代码
import { NextResponse } from 'next/server';
import type { NextRequest } from 'next/server';export function middleware(request: NextRequest) {const { pathname } = request.nextUrl;// 检查用户是否有有效的登录 tokenconst token = request.cookies.get('authToken')?.value;if (!token && pathname.startsWith('/admin')) {// 如果未登录,重定向到登录页面return NextResponse.redirect(new URL('/login', request.url));}// 允许请求通过return NextResponse.next();
}
配置匹配路径
export const config = {matcher: ['/admin/:path*'], // 仅在 /admin 路径及子路径生效
};

示例 2:基于语言的动态重定向

根据用户浏览器的语言设置,将用户重定向到对应的语言页面。

中间件代码
import { NextResponse } from 'next/server';
import type { NextRequest } from 'next/server';export function middleware(request: NextRequest) {const { pathname } = request.nextUrl;// 如果路径已经包含语言前缀,则不处理if (pathname.startsWith('/en') || pathname.startsWith('/fr')) {return NextResponse.next();}// 获取用户的首选语言const preferredLanguage = request.headers.get('accept-language')?.split(',')[0] || 'en';// 根据语言重定向if (preferredLanguage.startsWith('fr')) {return NextResponse.redirect(new URL('/fr' + pathname, request.url));}// 默认重定向到英语页面return NextResponse.redirect(new URL('/en' + pathname, request.url));
}
目录结构
pages
├── en
│   └── index.tsx
├── fr
│   └── index.tsx
└── middleware.ts

示例 3:阻止指定 IP 地址的访问

我们希望屏蔽某些 IP 地址的用户。

中间件代码
import { NextResponse } from 'next/server';
import type { NextRequest } from 'next/server';const BLOCKED_IPS = ['123.45.67.89', '98.76.54.32'];export function middleware(request: NextRequest) {const clientIP = request.ip || request.headers.get('x-forwarded-for') || 'unknown';if (BLOCKED_IPS.includes(clientIP)) {// 如果 IP 被屏蔽,返回 403 Forbidden 响应return new NextResponse('Access forbidden', { status: 403 });}// 允许其他请求通过return NextResponse.next();
}
配置匹配路径
export const config = {matcher: ['/:path*'], // 对所有路径生效
};

示例 4:为某些请求添加自定义头

在 API 请求中注入特定的自定义头信息。

中间件代码
import { NextResponse } from 'next/server';
import type { NextRequest } from 'next/server';export function middleware(request: NextRequest) {const response = NextResponse.next();if (request.nextUrl.pathname.startsWith('/api')) {response.headers.set('X-Custom-Header', 'MyCustomValue');}return response;
}

http://www.yayakq.cn/news/344641/

相关文章:

  • 新蔡县城乡建设局网站购物网站素材
  • 做网站有哪些软件有专门做网站的公司
  • 国外创意网站设计欣赏如何让网站自适应屏幕
  • 网站建设与网页设计专业网站设计规划书怎么写
  • ASP.NET网站建设实战企业网站建设网站制作
  • 哪里有免费的网站自己做影视公司宣传片
  • 如何在百度上建网站网站做301跳转的方法
  • 自己做网站推广需要多少钱自已电脑做网站
  • 佛山品牌网站建设金华规划局网站开发区
  • 山东外贸网站是什么意思制作网页首页教程
  • 网站的建站方案网上最好的网站模块
  • 建设银行网站注册用户便宜电商网站建设
  • 浦江建设局网站厦门网站设计公司找哪家厦门电商系统
  • 网站制作公司 哪家好做网站怎么调用栏目
  • 网站icp备案认证怎么做十大著名企业文化
  • 电子商务网站推广的方法有哪些asp. net 做网站
  • 做网站网页需要多久正规营销型网站定制
  • 网站开发应用技术专业计算机软件开发工资高吗
  • 佛山网站建设公司88wordpress 是否登录
  • 在您的网站首页添加标签如何自己做企业网站
  • 如何做网站购物车建设商业门户网站的重要性
  • 国外做黄漫的网站有哪些西安品牌网站建设
  • 焦作网站网站建设网上购物商城数据库设计
  • 网站怎么快速做排名浙江网站
  • 营销类网站设计 要点上海搭建商
  • 商品网站建设格式微网站页面
  • seo站内优化技巧营销团队建设与管理
  • 山东网站空间静态页面网站怎么做
  • 做外贸网站哪家的好推广方法
  • 网站模板含数据库下载网站建设优化之优化关键字