I'm向节点服务器发送了一个文件,它给了我404状态错误
I'm sending a file to node server it gives me 404 state error
我的HTML文件如下所示,
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>file</title>
</head>
<body>
<form method="post" action="/getusrfile" enctype='multipart/form-data'>
<input type="file" name="fil" >
<button type="submit">
sub
</button>
</form>
</body>
</html>
我正在使用节点,表示为以下
app.post("/getusrfile",function(req,res){
console.log("came to server");// prints this
console.log(req.files);//prints undefined
//console.log(JSON.stringify(req.files.fil));
fs.readFile(req.files.fil, function (err, data) {
// ...
var newPath = __dirname + "/../public/uploadedFileName";
fs.writeFile(newPath, data, function (err) {
console.log(err);
res.send(err);
});
});
});
它打印到服务器,但没有在服务器上创建任何文件/目录。响应为"Cannot POST/getusrfile",状态为404。
和req.files打印未定义的
如何使其发挥作用?
第一个
$ npm install --save multer
然后在app.post函数之前添加multer中间件:
app.use(require('multer')({dest : __dirname }));
app.post("/getusrfile",function(req,res){
var filePath = req.files.fil.path;
fs.readFile(filePath, function (err, data) {
// ...
});
});
测试:
it('should respond "OK 200" to POST request with file payload',function(done){
var filePath = path.join(__dirname,'test.txt');
request(app)
.post('/getusrfile')
.attach('fil',filePath)
.expect(200)
.end(function(err,res){
expect(err).to.not.exist;
done();
});
});
相关文章:
- 当包含另一个asp文件时,是否也包含所有引用的样式和脚本页面
- 将jsp文件下拉列表中的选定项分配给一个java变量(比如String selection)
- 如何在android中使用phonegap将文件从一个文件夹移动/复制到另一个文件夹
- 如何在elfinder插件(一个文件管理器插件)上获得上传前事件
- 我应该如何从xml文件构建一个javascript页面
- Sails.js:同时发布文本输入和一个文件
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- 正在传递JSONP标头's数据参数到另一个文件中的AJAX请求
- 要求定义另一个文件中的对象
- 是否可以使用JavaScript/AAJAX在客户端创建一个文件
- SuiteScript2.0-包括一个自定义文件
- 有没有办法在tinymceiframe中加载一个外部javascript文件
- 如何将变量传递到另一个js文件
- 如何将所有JS文件连接到一个文件夹中
- 从Chrome扩展名中的popup.html文件在background.js文件中运行一个函数
- 如何用javascript发送多个文件没有jQuery我想要每个文件一个进度条
- 我正在尝试一个接一个地播放一个 mp3 文件(一个作为介绍),但它不起作用.我该怎么做
- Jquery结构-每个文件一个函数
- 如何将文件一个接一个地上传到谷歌驱动器使用谷歌应用程序脚本
- 将多个链接从txt文件一个接一个地插入到一个iframe中