gpt4 book ai didi

webpack - 在 next.js/api 函数处理程序中要求节点模块的正确方法是什么

转载 作者:行者123 更新时间:2023-12-04 03:35:05 24 4
gpt4 key购买 nike

我试图在我的/api 文件夹中的文件中要求 bcrypt。

// pages/api/login.js
const bcrypt = require('bcrypt');

export default async function handler(req, res) {
switch (req.method) {
case 'POST':
// do stuff with bcrypt
res.status(200).json()
break
default:
res.status(405).end() //Method Not Allowed
break
}
}
当我使用 时一切正常npm 运行开发 但是当我运行 npx 无服务器 我收到此错误:
ModuleNotFoundError: Module not found: Error: Can't resolve 'mock-aws-s3'
经过大量研究,这似乎正在发生,因为 webpack 试图将 bcrypt 包含在客户端包中,而它应该只包含在服务器端。我不明白为什么会发生这种情况,因为根据 Next.js 文档:
Any file inside the folder pages/api is mapped to /api/* and will be treated as an API endpoint instead of a page. They are server-side only bundles and won't increase your client-side bundle size.
我通过使用 eval 找到了解决此问题的方法
const bcrypt = eval("require('bcrypt')");
但这感觉很hacky,就像我没有正确理解next.js。处理这种情况的正确方法是什么,为什么 webpack 试图将文件包含在/api 中?

最佳答案

我之前遇到过这个问题,请确保同时包含 node_modules文件夹和 package.json无服务器配置文件中的文件。如果排除其中任何一个,则会抛出上述错误。
编辑:
@tarandeept
这是我的包裹的截图:
enter image description here
这是我的文件夹结构:
enter image description here

关于webpack - 在 next.js/api 函数处理程序中要求节点模块的正确方法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67070288/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com