基于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)
1.3 path的方法
path.dirname():取dir
path.basename():取base
path.extname():取ext
path.parse(str):把str转为obj
path.format(obj):把obj转为str
path.resolve():把两个path片段合为一个
path.isAbsolute(path):是否是绝对路径
path.relative(from, to):path.relative() 方法返回从 from 到 to 的相对路径。
path.normalize(path):标准化path
path.join([...paths]):使用平台特定的分隔符把全部给定的path片段连接到一起,并规范化生成的路径。
path.delimiter:提供平台特定的路径分隔符:Windows 上是 ; POSIX 上是 :
path.sep:提供了平台特定的路径片段分隔符:Windows 上是 POSIX 上是 /
2. filesystem常用方法
fs.readFile: 读文件
fs.readdir:读文件夹
fs.writeFile:写文件
fs.mkdir:建文件夹
fs.stat:文件状态
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>
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。