如何解决已解决:强大的在本地主机之外不起作用
我使用强大的工具制作了一个基本的文件上传网站。文件上传器在我的本地主机上工作,但是当其他设备使用我的网站上传文件时,它不起作用,我收到来自 await fs.writeFile(newPath,rawData);
的错误。我检查了 formidable 的 files
对象,并将 files.name
属性设置为 ''
(它在我上传时设置为文件名,但是当其他设备上传时它设置为 {{1} })。此外,当其他设备上传时,路径 ''
处的文件始终为空。
files.path
当我的笔记本电脑以外的计算机上传时,这是一个强大的 import express from "express";
import path from "path";
import fs from "fs/promises";
import { Fields,Files,IncomingForm } from "formidable";
const formidable = require("formidable");
const PORT = 8000;
const app = express();
const resourcePath = path.resolve(__dirname,"..","resources");
app.get("/",async (req,res) => {
res.sendFile(path.resolve(__dirname,"public","index.html"));
});
app.post("/api/upload",(req,res,next) => {
console.log("/api/ hit");
const form: IncomingForm = new formidable.IncomingForm();
// let form: IncomingForm = formidable({ multiples: true });
form.parse(req,async (err: any,fields: Fields,files: Files) => {
if (err) {
console.log("THERE WAS ERROR!");
next(err);
return;
}
const oldpath: string = files.someExpressFiles.path;
const newPath: string = path.join(
__dirname,files.someExpressFiles.name
);
// raw data
let rawData: any;
try {
rawData = await fs.readFile(oldpath);
} catch (err) {
console.log("1",err);
}
try {
await fs.writeFile(newPath,rawData);
res.send("Successfully uploaded");
} catch (err) {
console.log("2",err);
}
});
});
对象:
files
我的 html 文件:
files {
someExpressFiles: File {
_events: [Object: null prototype] {},_eventsCount: 0,_maxListeners: undefined,size: 0,path: 'C:\\Users\\myName\\AppData\\Local\\Temp\\upload_75928c3230dd986d613067faeb3df9ff',name: '',type: 'application/octet-stream',hash: null,lastModifiedDate: null,_writeStream: WriteStream {
_writableState: [WritableState],_events: [Object: null prototype] {},fd: 3,flags: 'w',mode: 438,start: undefined,autoClose: true,pos: undefined,bytesWritten: 0,closed: false,[Symbol(kFs)]: [Object],[Symbol(kCapture)]: false,[Symbol(kIsPerformingIO)]: false
},[Symbol(kCapture)]: false
}
}
有谁知道为什么会发生这种情况以及解决方法,以便文件上传可以在另一台设备上工作?
解决方法
实际上没有错误。我得到的错误是由于原始代码库中的糟糕设计导致的用户错误引起的,看起来与此处发布的代码略有不同。此处发布的代码实际上完全正常。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。