Nodejs 入门 - 上传文件

1.安装Formidable

npm install formidable

     Formidable中封装了传输文件需要使用的函数,方便易用。

2.前端

   由于需要上传文件,注意设置 enctype="multipart/form-data"。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <form action="http://127.0.0.1:3000/Resources" method="POST" enctype="multipart/form-data">
    <p>
        姓名:<input type="text" name = "name"/>
    </p>
    <p>
        年龄:<input type="text" name = "age"/>
    </p>
    <p>
        性别: <input type="radio" name = "sex" value="男"/>男
              <input type="radio" name = "sex" value="女"/>女
    </p> 
    <p>
        图片:<input type="file" name = "image"/>
    </p>
    <p>
        <input type="submit"/>
    </p> 
    </form>
</body>
</html>

3.服务器端

     服务器将客户上传的文件,保存到目录“./image”。

var http = require("http");
var url = require("url");
var querystring = require("querystring");
var formidable = require("formidable");

var server = http.createServer(function(req, res){
   if(req.url == "/Resources" && req.method == "POST"){
       var form = new formidable.IncomingForm();
       form.uploadDir= "./image";
       form.parse(req,function(err, fields, files){
           if(err){
                throw err;
           }      
            console.log(fields);    //文本 
            console.log(files);     //文件
            res.writeHead(200, {"Content-type":"text/plain"});  
            res.end("success");
       });
   }
});
 
server.listen(3000,"127.0.0.1");

4.执行结果

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值