이 글에서는 node.js가 multer 미들웨어를 사용하여 게시물 파일 업로드 문제를 해결하는 방법을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.
관련 권장 사항: "nodejs 튜토리얼"
body-parser 미들웨어는 실제로 "매우 불완전"합니다. "순수한 데이터"만 처리할 수 있습니다.
우리 모두 알고 있듯이 post는 다음 두 가지 용도로 자주 사용됩니다.
데이터 제출(포스트 양식 제출)
파일 업로드
그러나 "유명한" body-parser는 첫 번째 작업만 수행할 수 있습니다.
불편해요...
이전에 작성한 이미지 파일 업로드 기사에 강력한 모듈이 사용되었습니다. 그 핵심은 다음과 같습니다.
var form=new formidable.IncomingForm();
다음 form.uploadDir
및 field/end 모니터링< /em> … 모두 이를 기반으로 합니다. form.uploadDir
、field/end的监听 … 都是基于此。
好了这里我们要说的是缺点:和body-parser一样,formidable插件只能用来处理图片格式,也是一大遗憾了。
于是,笔者找到了 multer中间件 ,希望它能“拯救者支离破碎的山河” (呵呵)
(c)npm install express multer
const express = require('express'); const bodyparser = require('body-parser');//解析post数据 const multer = require('multer'); //解析Post文件 const fs = require('fs'); const pathlib = require('path'); //解析文件路径 var server = express(); var objMulter = multer({dest:'./www/upload'}); //用户上传文件存入dest目录下 server.use(objMulter.any()); //处理任何用户上传的文件 //处理post文件数据 server.post('/',function(req,res){ console.log(req.files[0].originalname); //req.files post文件 originalname为文件名 //获取原始拓展名+后缀名 var newName = req.files[0].path+pathlib.parse(req.files[0].originalname).ext; //重命名 fs.rename(req.files[0].path,newName,function(err){ if(err){ res.send('上传失败'); }else{ res.send('上传成功'); } }); }); server.listen(8081);
这里,用req.files顶替了req.body:因为body中只能存放(文字)数锯——这里如果用body-parser的话,看到的只是控制台上显示的文件名。
代码中objMulter.any()
作用是“ 获取所有数据 ”;
与any()
相对的还有一个single()
,它里面要指定一个参数——前端<input>
里的name名!如本例中还可以这样写:
server.use(objMulter.single('f1'));
前端代码如下 —— 文件提交,指定格式为multipart/form-data
그래서 저자는 "깨진 산과 강을 살릴" 수 있기를 바라며multer 미들웨어
<form action="http://localhost:8081/" method="post" enctype="multipart/form-data"> 文件:<input type="file" name="f1" /><br /> <input type="submit" value="上传" /> </form>
var http = require('http'); var fs = require('fs'); var path = require('path'); var server = http.createServer(function (req, res) { var method = req.method; // 获取请求方法 if (method === 'POST') { // 暂只关注 post 请求 var dataStr = ''; req.on('data', function (chunk) { // 接收到数据,先存储起来 var chunkStr = chunk.toString() dataStr += chunkStr }); req.on('end', function () { // 接收数据完成,将数据写入文件 var fileName = path.resolve(__dirname, 'post.txt'); fs.writeFile(fileName, dataStr) res.end('OK'); }); } }); server.listen(8081);
objMulter.any()
의 기능은 "모든 데이터를 가져오는 것"입니다. any(와 반대되는 <code>single()
도 있습니다. ) > , 매개변수(프론트 엔드 <input>
의 이름)를 지정해야 합니다! 예를 들어, 이 예에서는 다음과 같이 작성할 수도 있습니다. rrreee프런트 엔드 코드는 다음과 같습니다. 파일 제출, 형식을 multipart/form-data
로 지정: rrreee
위 내용은 node.js는 multer 미들웨어를 사용하여 파일을 업로드합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!