node学习笔记
2019-03-01 本文已影响2人
margery
一、什么是node
node.js
1.Node.js 就是运行在服务端的 JavaScript
2.Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台。
3.Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好。
node的特点
1.异步I/O
```
$.post('url',,{title:'学习node的笔记'},function(data){
console.log('收到相应')
})
console.log('发送Ajax结束')
```
2.事件与回调函数
3.单线程
4.跨平台
node.js创建第一个应用
可以直接在命令行运行.js文件(不推荐使用)
最优选择:新建.js 文件
1.引入require模块
var http = require('http');// const http = require('http');
2.创建服务,服务器可以监听客户端的请求
var server = http.createServer(function(req, res) {
console.log('111');
});
3.监听请求
server.listen(8081);
二、npm 是什么
npm由三部分组成
1.网站
2.注册库(registry)
3.命令行工具(CLI)
+ 网站是开发者使用npm的最基本方法,包括发现/查找package,编写说明,管理他们的npm各个方面。
+ 注册库(registry)是一个关于package信息的一个巨大的库。
+ CLI 通过命令行或者终端,这是开发者通过CLI与npm打交道的途径。
用npm 可以做什么
1.为你的应用使用package,或者直接使用他们
2.下载可以立即使用的独立的工具(第三方工具)
3.无需下载下使用npx运行package
4.分享你的代码向任何一个npm使用者
5.对特定的开发者限制代码
6.组成虚拟的团
7.管理多个版本的代码和代码依赖的版本
8.当代码更新时很容易的更新应用
9.多种方法去解决同一个疑问
10.去发现在相同的问题上其他的开发者
如何查找package
去发现package,打开你的npm搜索栏
当你浏览时,你会发现
+ node 模块(node modules) 可以在服务器端使用
+ 在命令行中添加命令供您使用的包
+ 可以用到网站浏览器端的package
实例——找到一个package
例如,假设你想为你的应用找一个条形码(二维码),预期花费数周时间来设计和实现,还不如去看下是否有人已经上传了一个二维码的package。
1.从搜索框输入值开始
2.相关选项将出现
3.或者点击,去过滤更多的有可能的
4.当你选择一个package去探索,更多的信息会展示出来,这些信息是package的作者写的,很详细。
5.现在你可以浏览开发者文档,去学习如何使用这些package。
三、文件系统 fs
readFile('文件名',function(err,data){})
writeFile('文件名','新增内容',function(err,data){})
四、get post
get 在url中 数据跟在url后边的
post 不在url中 数据单独发的
GET 数据解析
1、自己切
2.querystring xxx=xx&xx=xx
3.urlLib aa?xxx=xx&xx=12
urlLib.parse(url,true) pathname/query
url
const urlLib = require('url')
var obj = urlLib.parse('http://www.bufanui.com/index?a=2&b=5',true) //加上true 自动将query解析成json
console.log(obj);
Url {
protocol: 'http:',
slashes: true,
auth: null,
host: 'www.bufanui.com',
port: null,
hostname: 'www.bufanui.com',
hash: null,
search: '?a=2&b=5',
query: 'a=2&b=5',
pathname: '/index',
path: '/index?a=2&b=5',
href: 'http://www.bufanui.com/index?a=2&b=5' }
querystring
const querystring = require('querystring')
var json = querystring.parse("user=shi&pass=shi")
console.log(json);//{ user: 'shi', pass: 'shi' }
post
数据量大,url集中在内容
分段发送
五、模块化
1、系统模块:http/querystring/url
2、自定义模块:
3、包管理器
系统模块:
断言:Assert
Buffer
c/c++ 扩展
Crypto 加密
Path 处理文件路径
Stream 流操作
。。。
自定义模块
1.模块的组成
require 请求,引入其他模块的 (系统模块、自定义模块)
modules 模块,批量对外输出
exports 输出,对外输出
2.npm (NodeJS Package Manager) 包管理器
1.统一下载途径
2.自动下载依赖
3.node_modules 存放依赖
( 如果有./ 从当前目录找
如果不加./ 先从系统模块找,再从node_modules找 )
自定义的模块,统一放在node_modules中
3.如何发布自己的模块
创建一个新的文件夹,npm init
编写包的逻辑
npm publish,上传成功,npm --force unpublish (取消发布)
注意:引入自己的模块,路径加./
对外输出内容 ,必须加exports
js 可加可不加
六、express框架
简洁而灵活的 node.js Web应用框架
1.安装
npm install express --save
2.配置
3.接受请求 get/post/use
4.响应数据
非侵入式(增强式)
req req.url
res
原生 res.write()
express res.send() // 功能更多
优势:express 保留了原生的功能,添加了一些方法,增强原有的功能
使用三部曲:
1.创建服务 var server = express()
2.监听 server.listen()
3.处理请求 server.use('地址',function(req,res){})
处理请求三种方式:
get('/',function(req,res){})
post()
use() 融合两种请求
中间件 (使用、写、链式)
eg:express-static //设置静态文件路径
const static = require('express-static')
server.use(static('/'))
自己写
server.use(function(req,res,next(){
var str = ''
req.on('data',function(){
str += data
})
req.on('end',function(){
req.body = querystring.parse(str);
next()
})
}))
处理数据
GET 无需中间件
req.query
POST 需要 body-parser
server.use(bodyParser.unlencode({})) //用于处理 JSON, Raw, Text 和 URL 编码的数据
server.use(function(){
req.body
})
server.use(function(req,res,next(){
req.body
}))
链式操作
next() 下一个步骤
七、cookie
cookie
存在浏览器中 保存一些数据,每次请求都会带过来
不安全、有限(4K)
签名、加密
session
保存数据,保存在服务端
安全、足够大
不能独立存在、基于cookie实现的
cookie 中会有一个session的id、服务器利用session找到session文件、读取写入
隐患:session劫持
cookie
1、读取 cookie-parser
server.use(cookieParser("相同的签名 "))
server.use(function(){
req.cookies ==>未签名的cookie
req.signedCookies 签名
})
2、发送 response响应回去的
res.secret = ''
res.cookie('名字','值',{
path:'/aaa', // 向上继承
maxAge:30*24, // 毫秒
signed:ture // 是否签名 签名的密钥
})
3、删除
res.clearCookie('名字')
4、cookie-encrypter 加密
session
cookie-session
server.use(cookieParser())
server.use(cookieSession({
keys:['12','sss'],// 密钥
maxAge: 3600*1000, // 毫秒
}))
server.use('/',function(){
req.session
})
delete res.session
1、写入
2、读取
八、模板引擎 (渲染页面)
jade -破坏式、强依赖 不保持原来html
render('字符串)
renderFile('文件名',参数)
根据锁进,规定层级
属性放在(),逗号分隔
style = {}
class = []
内容 空格 依次
| 原样输出
. 所有的下一级 原样输出
include a.js
# {a+b } 输出内容
- var a = 5 / for
!标签正常输出
ejs -非侵入式 保留式
<%= name %>
<%= 12+5 %>
<%= 'fefefe' %>
<%= json.arr[0].name %>