一:简单的Node.js介绍
简单的说Node.js是运行在服务端的javascript
Node.js 是基于Chrome V8引擎的javascipt运行环境
Node.js 使用了一个事件驱动、非阻塞式I/O模型,使其轻量高效
Node.js 的包管理器npm,是全球最大的开源库生态系统。node中的所有的模块都可以 在npm中找到并下载使用
二:Node杂七杂八的东西
(1)安装:直接打开安装包安装就行,一般安在c盘;安完以后吧,在Dos窗口上输入node -v来检查你的版本号 还有npm -v
(2)让程序在node环境中运行起来
如果用的不是webstorm这个编辑器的话,其他的话:
打开控制台
cd 把文件托拉进来
node 要执行的文件名
三:编写一段http服务器代码
先引入http模块(node的相关功能都是由模块提供的,所以要使用http服务,就要引入http模块)
// 引入http模块
(1) var http = require('http');
//创建http服务
(2) var server = http.createServer(function(req,res){
//在创建http服务时,传入了一个回调函数作为参数,在收到客户端请求时(就是在用户通过浏览器地址栏发送请求时)会触发这个回调函数
这个回调函数里的俩参数
req:请求对象:可以从这个参数里获取到 请求路径req.url 请求方法req.method 等
res:响应对象:可以通过这个参数向客户端发送信息( res.write()/res.send()一般是在控制台上打印出来的东西);
发送页面(res.sendFile()一般在用这个方法的时候要引入fs模块,fs模块会在下面进行解释)
})
//配置路由
就是根据用户在浏览器地址栏上输入的网址请求的不同路径,向前端发送不同的数据呀,页面呀啥的(下面是一个简单的没有参数的get请求服务)
(3)var server = http.createServer(function(req,res){
if (req.url=='/index.html'||req.url=='/'){
res.write('开新');
res.end();
//这是向客户端发送一些数据,并不是网页,当然会在页面上显示出来嘛
var path=fs.realpathSync('index.html');
res.sendFile(path);
//使用文件的读写操作把存在服务器中的文件写进res里
var rs=fs.createReadStream('./login.html');
rs.pipe(res);
//上边这两种都是用来向客户发送回来网页的
}
如果用户请求的文件在服务器中不存在,就利用状态吗返回对应的编码
res.statusCode = 404;
res.end('not found)
})
//监听服务器端口号
server.listen(8888,function () {
console.log('服务器启动完毕');
})
咱们在这再说个url模块
url模块下的parse方法可以把请求的url由字符串转为对象
完整的代码
var http = require('http');
var url = require('url');
var fs = require('fs');
var server = http.createServer(function(req,res){
//路径转换
var urlObj = url.parse(req.url,true);
console.log(urlObj.path);//获取请求的路径
console.log(urlObj.query)//获取get
提交的参数
if (urlObj.pathname=='/index'||urlObj.pathname=='/'){
var rs=fs.createReadStream('./index.html');
rs.pipe(res);
}else if(urlObj.pathname=='./login'){
//验证用户名和密码
if(urlObj.query.user=='123'&&urlObj.query.pass=='234')
var rs=fs.createReadStream('./success.html');
rs.pipe(res);
}else{
var rs=fs.createReadStream('./error.html');
rs.pipe(res);
}else{
res.statusCode = 404;
res.end('404')
}
})
server.listen(8888,function () {
console.log('服务器启动完毕');
})
当引入外部文件时,比如css啥的
//判断:请求的页面是否存在
var bol = fs.existsSync('.'+urlObj.pathname);
//路由
if (bol){
var rs=fs.createReadStream('.'+urlObj.pathname);
rs.pipe(res);
}else{
res.statusCode = 404;
res.end('404')
}
四 :fs模块
fs模块又叫文件模块;此模块提供了 对本地磁盘中的文件读写、创建、删除、以及文件目录操作的相关方法
首先我们要先把模块引进来
var fs = require('fs');
(1)文件读取:(异步读取)
fs.readFile('data.txt',function (err,data) {//从磁盘里读文件
//err在读取失败时有值,有值是错误信息,如果没错则err为null,data参数中保存的就是读取出来的数据
if (err){
console.log(err);
}else{
console.log(data);
}
})
(同步读取)
var str = fs.readFileSync('./smile.txt','utf-8')
console.log(str);
(2)写入文件
(异步写入)
fs.writeFile('hello.txt','hello world',{
文件写入操作:writeFile(a,b,c,d)a:要写入的路 径,如果路径不存在就创建这个路径;b:要写入的数据,c:写入的操作;d:写入结束的回调函数
flag:'w'//a,表示拼接写入,如果文件中已经有数据则在元数据的末尾拼接新数据;w:是覆盖式的写入,如果文件中已经有数据,就会覆盖原来的数据
},function (err,data) {
console.log(err);
console.log(data);
})
(同步写入)
var str = 'sdssdsds';
fs.writeFileSync('./smile.txt',str,{flag:'a'})
(3)复制文件
文件的复制操作,当数据成功读取后载写入另一个文件中
fs.readFile('data.txt',function (err,data) {
if (err){
console.log(err);
}else{
fs.writeFile('data副本.txt',data,{
flag:'w'
},function (err) {
if (err){
console.log(err);
}else{
console.log('复制成功');
}
})
}
})
fs模块还有创建新目录啥的功能,先不写,因为为忘了,等我想明白了再写吧
五:文件的管道流操作
使用管道流操作与普通读写操作的区别:管道流操作使用流式读取,写入文件每读取64k时就执行一次写入操作
而普通读写操作需要先把文件全部读取进内存以后才进行写入,这样容易造成内存溢出
//管道流读写
var fs=require('fs');
//吧文件分割成若干块,每一块大小是64k,逐块操作这个文件,来达到节约内存的目的
var rs=fs.createReadStream('data.txt');//创建读入流
var ws=fs.createWriteStream('hello.txt');//创建写入流
读取流载每读出64k的数据后,会触发一次data事件,通过该事件函树拿到读取出来的数据
rs.on('data',function (chunk) {//事件函数的参数chunk保存的就是读取流每次读取出来的数据,如果没有指定读取编码,则默认一buffer格式读取
// console.log(chunk.toString());
// ws.write(chunk,function () {//通过写入流的write方法把要写入的数据通过写入流写入
// console.log('写入结束');
// })
})
也可以直接:
rs.pipe(ws);//rs读取流下的pipe方法参数是写入流对象,该方法可以把读取流当前读出的64k数据传给写入流,当写如流写入完成再进行后续的读取操作
pipe操作为同步操作,只有当读取出来的数据写入完成后才进行下一次的读取操作,保证内存中没有积压数据,但是会延长读写时间
data时间在读的同时写入,读写互不干扰。但是由于磁盘读写速度不一致会有积压数据的现象,但是能缩短读写时间
未完待续..........