简单的node.js

一:简单的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时间在读的同时写入,读写互不干扰。但是由于磁盘读写速度不一致会有积压数据的现象,但是能缩短读写时间
未完待续..........

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容

  • Node.js 常用工具 util 是一个Node.js 核心模块,提供常用函数的集合,用于弥补核心JavaScr...
    FTOLsXD阅读 535评论 0 2
  • 个人入门学习用笔记、不过多作为参考依据。如有错误欢迎斧正 目录 简书好像不支持锚点、复制搜索(反正也是写给我自己看...
    kirito_song阅读 2,467评论 1 37
  • //公共引用 varfs =require('fs'), path =require('path'); 1、读取文...
    才気莮孒阅读 832评论 0 1
  • Node.js是目前非常火热的技术,但是它的诞生经历却很奇特。 众所周知,在Netscape设计出JavaScri...
    w_zhuan阅读 3,612评论 2 41
  • 首先,我们要理解node.js的概念,以及他的用法。node.js 是帮助我们架设外部服务器,来进行外部服务的提供...
    风清扬101阅读 427评论 0 1