node中fs模块和http模块的简单介绍

读取文件 fs 模块

第1个参数就是要读取的文件路径
第2个参数是一个回调函数(error,data)=>{}
error如果读取失败,error 就是错误对象 如果读取成功,error 就是 nu1l
data如果读取成功,data 就是读取到的数据,输出来的是是16进制的数据,可以通过 data.toString() 转换一下。如果读取失败,data就是undefined 

简单读取文件

var fs = require('fs')
fs.readFile('./test.txt', (error, data) => {// 如果读取成功,error就是nullif (!error) {console.log('成功error是:', error) //输出的是nullconsole.log('读取成功data数据是:', data) //16进制的字符串console.log('我可以识别的:', data.toString()) //转为我们人可以识别的} else {console.log('读取失败')}
}) 

文件写模块

第1个参数:文件路径;
第2个参数文件内容
第3个参数是回调函数 (error,data)=>{}
error的值是null,说明成功。 error的值是错误对象,读取失败
data的值是 undefined的时候,可能成功也有可能是失败 
let fs = require('fs');
let fileCont='我是文件内容'
fs.writeFile('./文件名-用node写',fileCont, (erro, data) => {if (!erro) {console.log('写入成功了',data)} else {console.log('写入失败了',data)}
})
// 在你的项目中会多一个文件的哈,文件名是(文件名-用node写) 

http模块

server.on('request', (request,response) => {})
request 请求事件函数,可以接收两个参数:
第1个参数 Request 请求对象:请求对象可以用来获取客户端的一些请求信息,例如请求的路径
通过Request.url可以知道请求的路径

第2个参数 Response 响应对象:响应对象可以用来给客户端发送响应消息。
response对象上有一个方法,response.write()可以给客户端发送消息。
可以多次使用,不会出现覆盖。需要注意的是:发送完消息后,一定要使用response.end()
来告诉服务器,我的消息,已经发送写完了,你可以发送了

小技巧:我们也可以直接使用 response.end() 来发送数据 

使用http模块创建一个简单的服务器,并发送消息

let http = require('http')
// 使用 http.createServer创建一个实例
let server = http.createServer()
// 监听request请求
server.on('request', (request,response) => {console.log('监听到了路径是', request.url)response.write('hhhe')response.end() //消息写入完了,你可以发送了。
})
//绑定端口号,启动服务
server.listen(3000, () => {console.log('服务启动成功,通过127.0.0.1:3000可以来访问')
}) 
简单说一下为什么在浏览器中看见的地址是:http://127.0.0.1:3000。
但是我们通过 request.url 看见的是 / 这个问题?
其实,你把浏览器的地址复制下来就是”http://127.0.0.1:3000/“
这下知道原因了吧。 

给客户端的数据的2个注意点

第1个注意点:发送中文乱码问题
你发送的如果是中文。如:response.write('高启强')
客户端看见的是乱码 
怎么解决中文乱码问题
使用setHeader方法,只用设置请求头。
response.setHeader('Content-Type','text/html; charset=utf-8');
需要注意的是:设置请求头的代码要放置在 response.write 的前面
需要注意的是:设置请求头的代码要放置在 response.write 的前面
需要注意的是:设置请求头的代码要放置在 response.write 的前面

server.on('request', (request,response) => {//需要注意的是:设置请求头的代码要放置在 response.write 的前面response.setHeader('Content-Type','text/html; charset=utf-8');response.write('高启强')response.end()
}) 
第2个注意点:给客户端的数据只能是字符串或者二进制的数据
特别提醒:响应内容(给客户端的数据只能是字符串或者二进制的数据)
我们如果给一个数组,在控制台就会报错
server.on('request', (request,response) => {let back = ['高启强','安欣']response.write(back)response.end()
})
在控制台提示:
TypeError [ERR_INVALID_ARG_TYPE]: 
The first argument must be of type string or an instance of Buffer or Uint8Array.
Received an instance of Array 
怎么解决默认只能发送字符串或者二进制的数据
//使用 JSON.stringify()转化为字符号
server.on('request', (request,response) => {let back = ['高启强','安欣']//注意:设置请求头需要放置在发送的前面response.setHeader('Content-Type','text/html; charset=utf-8');//这里使用 response.end 也可以发送数据response.end(JSON.stringify(back))
}) 
## 最后 最近找到一个VUE的文档,它将VUE的各个知识点进行了总结,整理成了《Vue 开发必须知道的36个技巧》。内容比较详实,对各个知识点的讲解也十分到位。 > **有需要的小伙伴,可以点击下方卡片领取,无偿分享**

猜你喜欢

转载自blog.csdn.net/web22050702/article/details/129945307