# fs 模块
# readFile
- 使用
fs.readFile
方法,可以读取指定文件中的内容,语法格式如下
| fs.readFile(path[, options], callback) |
| |
| const fs = require('fs') |
| |
| |
| |
| |
| |
| |
| fs.readFile('./files/data.yml', 'utf8', function (err, data) { |
| if(err) return console.log('读取文件失败', err.message); |
| |
| console.log('读取文件成功', data); |
| }) |
# writeFile
- 使用 fs.writeFile 方法,可以向指定的文件中写入内容,语法格式如下:
| fs.writeFile(file, data[, options], callback) |
| const fs = require('fs') |
| |
| |
| |
| |
| |
| fs.writeFile('file', data, 'utf8', (err) => { |
| |
| |
| console.log(err) |
| }) |
# __dirname
- 在使用 fs 模块操作文件时,如果提供的操作路径是以 ./ 或 ../ 开头的相对路径时,很容易出现路径动态拼接错误的问题
- 原因:代码在运行的时候,会以执行 node 命令时所处的目录,动态拼接被操作文件的完整路径
- 解决方案:在使用 fs 模块操作文件时,直接提供完整的路径,不要提供 ./ 或../ 开头的相对路径,从而防止路径动态拼接的问题
| const fs = require('fs') |
| |
| |
| fs.writeFile(__dirname + './txt', data, 'utf8', (err) => { |
| console.log(err) |
| }) |
# path 模块
- path 模块是 node.js 官方提供的、用来处理路径的模块。它提供了一系列的方法和属性,用来满足用户对路径的处理需求
- path.join () 方法,用来将多个路径片段拼接成一个完整的路径字符串
- path.basename () 方法,用来从路径字符串中,将文件名解析出来
# join
| const path = require('path') |
| |
| |
| fs.readFile(path.join(__dirname, './txt'), 'utf8', (err, data) => { |
| if(err) return console.log(err.message) |
| console.log(data) |
| }) |
# basename
- 使用 path.basename () 方法,可以获取路径中最后一部分,经常通过这个方法获取路径中的文件名
| path.basename(path[, ext]) |
- path <string> 必选参数,表示一个路径的字符串
- ext <string> 可选参数,表示文件扩展名
- 返回 <string> 表示路径中的最后一部分
| const path = require('path') |
| |
| const fpath = '/a/b/c/index.html' |
| |
| |
| const fullName = path.basename(fpath) |
| console.log(fullName) |
| |
| |
| const nameWithoutExt = path.basename(fpath, '.html') |
| console.log(nameWithoutExt); |
# extname
- 使用 path.extname () 方法,可以获取路径中的扩展名部分
| const path = require('path') |
| |
| const fpath = 'index.html' |
| |
| const fext = path.extname(fpath) |
| |
| console.log(fext) |
# http 模块
# req 请求对象
| server.on('request', (req, res) => { |
| |
| const url = req.url |
| |
| |
| const method = req.method |
| |
| const str = `Your request url is ${url}, and request method is ${method}` |
| |
| console.log(str) |
| }) |
# res 响应对象
- 在服务器的 request 事件处理函数中,如果想访问与服务器相关的数据与属性,可以使用如下方式
| server.on('request', (req, res) => { |
| |
| const url = req.url |
| |
| |
| const method = req.method |
| |
| const str = `您请求的 URL 地址是 ${url}, 请求的 method 类型为 ${method}` |
| |
| |
| res.end(str) |
| }) |
- 解决中文乱码问题,需要设置响应头
Content-Type
的值为 text/html; charset=utd-8
| res.setHeader('Content-Type', 'text/html; charset=utf-8') |
# 案例
| const http = require('http') |
| |
| const server = http.createServer() |
| |
| server.on('request', (req, res) => { |
| |
| const url = req.url |
| |
| let content = '404 Not found!' |
| |
| |
| if (url === '/' || url === '/index.html') { |
| content = '<h2>首页</h2>' |
| } else if (url === '/about.html') { |
| content = '<h2>关于</h2>' |
| } |
| |
| |
| res.setHeader('Content-type', 'text/html; charset=utf-8') |
| |
| |
| res.end(content) |
| }) |
| |
| server.listen(8001, () => { |
| console.log('server running at http://127.0.0.1'); |
| }) |
# os 模块