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

相关文章

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

PyCharm 接入 DeepSeek最新完整教程

《PyCharm接入DeepSeek最新完整教程》文章介绍了DeepSeek-V3模型的性能提升以及如何在PyCharm中接入和使用DeepSeek进行代码开发,本文通过图文并茂的形式给大家介绍的... 目录DeepSeek-V3效果演示创建API Key在PyCharm中下载Continue插件配置Con

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

JS 实现复制到剪贴板的几种方式小结

《JS实现复制到剪贴板的几种方式小结》本文主要介绍了JS实现复制到剪贴板的几种方式小结,包括ClipboardAPI和document.execCommand这两种方法,具有一定的参考价值,感兴趣的... 目录一、Clipboard API相关属性方法二、document.execCommand优点:缺点:

Spring Boot整合log4j2日志配置的详细教程

《SpringBoot整合log4j2日志配置的详细教程》:本文主要介绍SpringBoot项目中整合Log4j2日志框架的步骤和配置,包括常用日志框架的比较、配置参数介绍、Log4j2配置详解... 目录前言一、常用日志框架二、配置参数介绍1. 日志级别2. 输出形式3. 日志格式3.1 PatternL

MySQL8.2.0安装教程分享

《MySQL8.2.0安装教程分享》这篇文章详细介绍了如何在Windows系统上安装MySQL数据库软件,包括下载、安装、配置和设置环境变量的步骤... 目录mysql的安装图文1.python访问网址2javascript.点击3.进入Downloads向下滑动4.选择Community Server5.

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

本地私有化部署DeepSeek模型的详细教程

《本地私有化部署DeepSeek模型的详细教程》DeepSeek模型是一种强大的语言模型,本地私有化部署可以让用户在自己的环境中安全、高效地使用该模型,避免数据传输到外部带来的安全风险,同时也能根据自... 目录一、引言二、环境准备(一)硬件要求(二)软件要求(三)创建虚拟环境三、安装依赖库四、获取 Dee