我正在为我的个人网站建立一个博客部分。由于以下错误,我无法打开博客文章:
(Vercel logs)
Error: ENOENT: no such file or directory, open '/var/task/src/content/hello.mdx'
at Object.openSync (node:fs:601:3)
at Object.readFileSync (node:fs:469:35)
at PostPage (/var/task/.next/server/app/posts/[slug]/page.js:381:45)
at S (/var/task/.next/server/chunks/789.js:6503:13)
at eb (/var/task/.next/server/chunks/789.js:6618:21)
at Array.toJSON (/var/task/.next/server/chunks/789.js:6422:20)
at stringify (<anonymous>)
at pb (/var/task/.next/server/chunks/789.js:6829:9)
at mb (/var/task/.next/server/chunks/789.js:6728:29)
at Timeout._onTimeout (/var/task/.next/server/chunks/789.js:6553:16) {
errno: -2,
syscall: 'open',
code: 'ENOENT',
path: '/var/task/src/content/hello.mdx'
}
当我访问我的作品集上的博客文章时,收到以下错误消息:
应用程序错误:服务器端发生异常(请参阅服务器日志以获取更多信息)。 摘要:2113801254
项目目录结构:
my-app/
└── src/
├── app/
│ ├── posts/
│ │ ├── page.js
│ │ └── [slug]/
│ │ └── page.js or PostPage
│ └── page.js
├── layout.js
├── page.js
├── components
├── content/
│ └── hello.mdx
└── fonts
Error 表明
PostPage
文件的代码有错误。我写了以下代码:
export default function PostPage({ params }) {
const post = fs.readFileSync(
path.join(__dirname, "../../../../../src/content/" + params.slug + ".mdx"),
"utf-8"
);
const { data: frontmatter, content } = matter(post);
const blog = DOMPurify.sanitize(
marked.parse(content, { mangle: false, headerIds: false })
);
.....
//returns jsx with markdown content
}
我尝试过更改
readFileSync()
中的路径,但在生产中没有任何作用。它正在本地开发模式下工作。请帮忙。
请注意,我是编程和 nextjs 或 vercel 的初学者。谢谢
您在这里使用了错误的路径 ->
path.join(__dirname, "../../../../../src/content/" + params.slug + ".mdx"),
'__dirname' 是您的根文件夹。尝试记录 __dirname
或者您应该使用 process.cwd()
我正在使用 process.cwd() 但我在 vercel 上遇到此错误
未处理的拒绝:错误:ENOENT:没有这样的文件或目录,打开 '/var/task/src/contents/projects/undefined.md'
关于开发
unhandledRejection:错误:ENOENT:没有这样的文件或目录,打开 'C:\Users\User\Desktop\My-Portfolio\sr