基于v6.10.3版本

1. path

1.1 Windows 与 POSIX

posix是和windows相对的,可以类比Unix。path在两种平台上表现不一样,如果想获取一致,那么统一为windows样式用path.win23;统一为posix样式用path.posix.

1.2 path的属性(dir,base,root,name,ext)

clipboard.png

clipboard.png

1.3 path的方法

  1. path.dirname():取dir

  2. path.basename():取base

  3. path.extname():取ext

  4. path.parse(str):把str转为obj

  5. path.format(obj):把obj转为str

  6. path.resolve():把两个path片段合为一个

  7. path.isAbsolute(path):是否是绝对路径

  8. path.relative(from, to):path.relative() 方法返回从 from 到 to 的相对路径。

  9. path.normalize(path):标准化path

  10. path.join([...paths]):使用平台特定的分隔符把全部给定的path片段连接到一起,并规范化生成的路径。

  11. path.delimiter:提供平台特定的路径分隔符:Windows 上是 ; POSIX 上是 :

  12. path.sep:提供了平台特定的路径片段分隔符:Windows 上是 POSIX 上是 /

2. filesystem常用方法

  1. fs.readFile: 读文件

  2. fs.readdir:读文件夹

  3. fs.writeFile:写文件

  4. fs.mkdir:建文件夹

  5. fs.stat:文件状态

  6. fs.rename(oldPath, newPath, callback):重命名,包括修改路径

3. 接受post参数 包括文件上传

const http = require('http');
const fs = require('fs');
const util = require('util');
const formidable = require('formidable');

http.createServer((req, res) => {
    if (req.url == '/favicon.ico') {
        res.writeHead(200, {
            'content-type': 'image/png;charset=utf-8'
        });
        fs.readFile('./static/images/favicon.png', data => {
            res.end(data);
        });
        return;
    } else if (req.url == '/') {
        res.writeHead(200, {
            'content-type': 'text/html;charset=utf-8'
        });
        fs.readFile('./static/index.html', (err, data) => {
            if (err) {
                console.log(err.to);
                res.end('err');
            } else {
                res.end(data);
            }
        });
    } else if (req.url == '/upload' && req.method.toLowerCase() == 'post') {
        var form = new formidable.IncomingForm();
        form.uploadDir = "./uploads"; // 如果当前路径不存在会报错
        form.parse(req, function(err, fields, files) {
            res.writeHead(200, {
                'content-type': 'text/plain'
            });
            res.write('received upload:\n\n');
            const oldPath = './' + files.icon.path;
            const newPath = './uploads/' + files.icon.name;
            fs.rename(oldPath, newPath, err => {
                if (!err) {
                    res.end(util.inspect({// inspect会把对象转为string
                        fields: fields,
                        files: files
                    }));
                }
            });
        });
    } else {
        res.end('done');
    }
}).listen(3000);

form页面:

// 加图片/文件上传的form必须加enctype为'multipart/form-data'
<form action="/upload" method="post"  enctype="multipart/form-data" >
    姓名:
    <input name="name" type="text"/>
    <br/>
    头像:
    <input name="icon" type="file"/>
    <br/>
    <input type="submit"/>
</form>

唯见长江天际流
827 声望11 粉丝

黄鹤楼送孟浩然之广陵