Next.js 12 On-Demand Revalidation 教程

2024-08-25 19:52

本文主要是介绍Next.js 12 On-Demand Revalidation 教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

On-Demand Revalidation 是 Next.js 自 11.1 版本开始支持的一项功能,它允许开发者通过 API 路由手动触发页面的重新验证和重新生成。这在需要手动控制内容更新,而不想等待增量静态生成(ISR,Incremental Static Regeneration)的默认时间间隔时,特别有用。

在 Next.js 12 中,这项功能得到了完全支持。下面是实现 On-Demand Revalidation 的完整教程。

1、配置环境变量

首先,需要配置一个用于安全验证的密钥。这个密钥将用于确保只有授权的请求才能触发页面的重新验证。

在项目根目录下创建 .env.local 文件,并添加以下内容:

REVALIDATION_SECRET=your_secret_token

可以将 your_secret_token 替换为任意一个复杂的字符串。

2、创建 API 路由

接下来,创建一个 API 路由,负责处理触发页面重新验证的请求。

在 pages/api/revalidate.ts 文件中,添加以下代码:

import { NextApiRequest, NextApiResponse } from 'next';export default async function handler(req: NextApiRequest, res: NextApiResponse) {const { secret, path } = req.query;// 验证密钥是否匹配if (secret !== process.env.REVALIDATION_SECRET) {return res.status(401).json({ message: 'Invalid token' });}try {// 重新验证指定的路径await res.revalidate(path as string);return res.json({ revalidated: true });} catch (err) {// 捕获并返回错误console.error('Revalidation error:', err);return res.status(500).json({ message: 'Error revalidating' });}
}

此代码创建了一个 API 路由 /api/revalidate,它接收两个查询参数:

secret: 用于验证请求的密钥。
path: 需要重新验证的页面路径。

3、配置页面的增量静态生成

需要在静态生成的页面中使用 getStaticProps 并设置 revalidate 属性来启用增量静态生成。

例如,在 pages/blog/[…slug].tsx 中:

import { GetStaticProps } from 'next';interface BlogPostProps {data: {title: string;content: string;};
}export const getStaticProps: GetStaticProps<BlogPostProps> = async ({ params }) => {const slug = params?.slug as string[];const data = await fetchYourData(slug.join('/'));return {props: {data,},revalidate: 60, // 设置页面60秒后重新生成};
};const BlogPost: React.FC<BlogPostProps> = ({ data }) => {return (<div><h1>{data.title}</h1><p>{data.content}</p></div>);
};export default BlogPost;

4、触发重新验证

要手动触发页面重新验证,可以向 /api/revalidate 路由发送 GET 请求。请求的 URL 结构如下:

https://yourdomain.com/api/revalidate?secret=your_secret_token&path=/blog/2024/07/demo-name

在此示例中:
your_secret_token 是在环境变量中配置的密钥。
/blog/2024/07/demo-name 是希望重新生成的页面路径。
可以在前端通过 fetch 发送请求,或从任何后台系统中触发这个请求。

5. 调试与错误处理

如果触发重新验证时遇到问题,确保:

路径与生成的静态页面路径完全一致。
使用的密钥与环境变量中的密钥匹配。
输出的错误日志能帮助定位问题。
可以在 catch 块中输出更详细的日志信息来调试:

try {await res.revalidate(path as string);return res.json({ revalidated: true });
} catch (err) {console.error('Revalidation error:', err); // 输出详细错误信息return res.status(500).json({ message: 'Error revalidating', error: err.message });
}

6、总结

通过 On-Demand Revalidation 功能,可以手动控制 Next.js 项目中的内容更新,而无需等待预设的增量静态生成时间。这不仅提升了灵活性,也使得内容更新能够更加即时。只需确保配置正确的安全密钥,并在需要时触发重新验证请求,即可利用这一功能。

这篇关于Next.js 12 On-Demand Revalidation 教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106505

相关文章

全网最全Tomcat完全卸载重装教程小结

《全网最全Tomcat完全卸载重装教程小结》windows系统卸载Tomcat重新通过ZIP方式安装Tomcat,优点是灵活可控,适合开发者自定义配置,手动配置环境变量后,可通过命令行快速启动和管理... 目录一、完全卸载Tomcat1. 停止Tomcat服务2. 通过控制面板卸载3. 手动删除残留文件4.

Python的pandas库基础知识超详细教程

《Python的pandas库基础知识超详细教程》Pandas是Python数据处理核心库,提供Series和DataFrame结构,支持CSV/Excel/SQL等数据源导入及清洗、合并、统计等功能... 目录一、配置环境二、序列和数据表2.1 初始化2.2  获取数值2.3 获取索引2.4 索引取内容2

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

在Node.js中使用.env文件管理环境变量的全过程

《在Node.js中使用.env文件管理环境变量的全过程》Node.js应用程序通常依赖于环境变量来管理敏感信息或配置设置,.env文件已经成为一种流行的本地管理这些变量的方法,本文将探讨.env文件... 目录引言为什么使php用 .env 文件 ?如何在 Node.js 中使用 .env 文件最佳实践引

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因