gpt4 book ai didi

node.js - 重命名文件夹时出现间歇性 EPERM 错误

转载 作者:太空宇宙 更新时间:2023-11-04 01:32:10 27 4
gpt4 key购买 nike


我正在使用 Multer 在我的 fs 中上传图像。 Multer 不允许您动态设置 fs 中的位置,因此我始终在同一文件夹中上传,然后使用 fs.renamesynch 更改文件夹的名称。
我使用同步版本是因为我认为我必须等待任务结束,否则,我在接下来需要与重命名功能同步的任务中将会出现问题。
但是,我间歇性出现错误,不知道如何解决
这是我的代码:

router.post("/changeprofile", ensureAuthenticated, (req, res) => {
upload(req, res, err => {
if (err) {
res.render("changeprofile", { msg: err });
} else {
if (req.file == undefined) {
res.render("changeprofile", { msg: "Error: No file Selected!" });
} else {
res.render("changeprofile", {
msg: "File Uploaded!",
file: `uploads/${req.file.filename}`
});
fsextra.removeSync("./public/profile" + id);
if (err) console.log(err);
else console.log("Deleted old folder");
glob("./public/uploads/profile.*", (err, matches) => {
if (err) console.log(err);
else {
console.log("renaming folder...");
fs.renameSync("./public/uploads", "./public/profile/" + id);
if (err) console.log(err);
else {
fs.mkdir("./public/uploads", err => {
if (err) console.log(err);
else
console.log(
"------------------FOLDER RECREATED---------------------------"
);
});
}
}
});
}
}
});
});



这是我收到的错误:
错误:EPERM:不允许操作,重命名“./public/uploads”->“./public/profile/21” 在 Object.renameSync (fs.js:593:3) 在 glob (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\routes\users.js:558:19) 在 f (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\once\once.js:25:25) 在全局。 (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:151:7) 在 Glob.emit (events.js:189:13) 在 Glob._finish (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:197:8) 完成 (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:182:14) 在 Glob._processReaddir2 (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:434:12) 在 C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:371:17 在 RES (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\inflight\inflight.js:31:16) 在 f (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\once\once.js:25:25) 在 Glob._readdirEntries (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:578:10) 在 C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\glob\glob.js:555:12 在 go$readdir$cb (C:\Users\Andrea\Desktop\LinkedinLikeSocialNetwork\node_modules\graceful-fs\graceful-fs.js:162:14) 在 FSReqWrap.args [未完成] (fs.js:140:20)

最佳答案

即使我没有得到答案,我认为我已经找到了解决方案:我认为问题是这样的。当您使用同步方法时,您可能认为 Node 在删除和重命名文件系统内的文件夹时也会与操作系统同步。但似乎并非如此:它会使用某些内核函数来调用操作系统,但随后对文件系统的管理是由操作系统进行的,并且 Node 不会等待函数的返回,即使您使用的是同步模式。例如,可能会发生所有 I/O 操作都将被缓冲然后一起执行以提高操作系统性能的情况。正确的想法是在执行 fs 操作后刷新操作系统缓存。但是,使用 fs-extra 和 Graceful-fs 我认为它现在可以正常工作:




var fs = require("graceful-fs");
const fsextra = require("fs-extra");
fs.gracefulify(realfs);

router.post("/changeprofile", ensureAuthenticated, (req, res) => {
upload(req, res, err => {
if (err) {
res.render("changeprofile", { msg: err });
} else {
if (req.file == undefined) {
res.render("changeprofile", { msg: "Error: No file Selected!" });
} else {
res.render("changeprofile", {
msg: "File Uploaded!",
file: `uploads/${req.file.filename}`
});
var path = "./public/profile/" + id;
if (fsextra.existsSync(path)){
fsextra.removeSync(path);
}
if (err) console.log(err);
else console.log("Deleted old folder");
glob("./public/uploads/profile.*", (err, matches) => {
if (err) console.log(err);
else {
console.log("renaming folder...");
fs.renameSync("./public/uploads", "./public/profile/" + id);
if (err) console.log(err);
else {
fs.mkdir("./public/uploads", err => {
if (err) console.log(err);
else
console.log(
"------------------FOLDER RECREATED---------------------------"
);
});
}
}
});
}
}
});
});














关于node.js - 重命名文件夹时出现间歇性 EPERM 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55742666/

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