1.nodejs的真正用途
nodejs,一个javascript的运行环境
运行在服务器作为web server
运行在本地,作为打包,构建工具
处理get请求
const http = require('http')
const querystring = require('querystring')
const server = htpp.createServer((req,res)=>{
//req 拥有的属性 url method 可以使用 querystring.parse(req.url.split('?')[1]) 获取参数
res.end('返回的数据')
})
搭建环境
在pakage.json的目录下 安装npm i nodemon cross-dev
在pakage.json文件里面的scripts里面添加"dev":"cross-env NODE_ENV=dev nodemon ./bin/www.js"
这样就可以直接在pakege.json目录下运行 npm run dev 启动当前服务
开发接口
初始化路由:根据之前的技术方案,做出路由
返回假数据:将路由和数据处理分离,以符合设计原则
在nodejs上操作数据库
npm i mysql
cookie 5KB 存储太小,用户的登录信息放在cookie里面不安全
session,登录实现的一种方式 通过生成随机数给cookie,登录后通过cookie里面的userid(随机数)在session中进行比对
实现判断是否已经登录
缺点:
1.目前session是js变量,放在Node进程内存中
2.进程内存有限,访问量过大,内存暴增怎么办
3.正式上线是多进程,进程之间内存无法共享
解决方案:redis
webServer最常用的缓存数据库,数据存放在内存中
相比于mysql,储存数据快(内存和硬盘不是一个数量级的)
但是成本更高,可存储的数据量更小(内存的硬伤)
将web server 和redis拆分成两个单独的服务
双方都是独立的,可拓展的(例如都是扩展成集群)
为何session适合用redis
session访问频繁,对性能要求极高
session可不考虑断点丢失数据的问题(内存的硬伤)
session数据量不会太大(相比于mysql中存储的数据)
安装和使用redis
https://www.runoob.com/redis/redis-install.html
在node js中使用redis
npm i redis --save
nginx 正向代理 相当于在家访问公司的内网,需要一个代理工具(客户端的)才能访问公司的内网
nginx反向代理 浏览器访问的还是一个地方(nginx做了处理),只是请求分为普通请求和/api请求
根据不同的访问地址,将请求代理到不同的地方 不受同源策略的影响
readline 一行一行读取文件
预防sql注入问题 使用mysql自带的escape函数 mysql.escape(对应的参数)并且去掉该参数的 ''
预防xss攻击 npm i xss --save 使用也是把对应的参数用xss(包裹住)
const xss =require('xss')
xss(content)
crypto node自带的加密插件
express是node最常用的web server框架
什么是框架
安装express
npm i express-generator
运行 express my-expressDemo 报以下错误
express : 无法加载文件 C:\Program Files\nodejs\node_global\express.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies。
所在位置 行:1 字符: 1
解决方法如下
1、打开终端
2、在终端执行:get-ExecutionPolicy,显示Restricted(表示状态是禁止的)
3、在终端执行:set-ExecutionPolicy RemoteSigned
4、在终端执行:get-ExecutionPolicy,显示RemoteSigned
koa2
1.安装koa2脚手架 npm i koa-generator
2.创建目录 koa2 blog-koa2
3.进入该文件夹 npm i 安装依赖
4.安装环境参数 npm i cross-env --save-dev
5.添加环境参数 在pakage.json文件里面的dev里面 前面加cross-env NODE_ENV=dev prd里面的前面可以加cross-env NODE_ENV=production
6.修改端口在bin文件夹下的www.js文件里面默认端口号是3000可以修改成为8000
koa2实现session
1.安装 npm i koa-generic-session koa-redis redis --save
连接mysql和使用xss
npm i mysql xss --save
日志记录
安装koa的morgan
npm i koa-morgan --save
创建logs文件夹并在该文件夹下创建access.log文件
在app.js里面引入fs path模块
pm2
下载安装
npm i pm2 -g
在package.json文件里面添加一行
"prd":"cross-env NODE_ENV=production pm2 start app.js" start app.js可以改成 start bin/www
pm2常用命令
pm2 restart app(app是当前的运行的app文件)
pm2 stop app 关闭当前服务
pm2 delete app 删除当前的服务
pm2 info app 查看当前app的所有详细信息
mongoDB
mongoDB 文档型类似json格式哦的数据库 而mysql是关系型 表格数据库
安装windows下的mongoDB
1.进入该网址https://www.mongodb.com/try/download/community
2.选择mongoDB Community Server
安装选择custom(自定义),可以把路径改为F:\MongoDB\log
如果出现错误就只接重新在以相同的路径安装一下就好
出现该错误直接点击ignore
进入安装的文件夹F:\MongoDB查看是否有data文件夹和log文件夹,没有的话自己创建一个
在data文件夹下创建一个db文件夹
在Log文件夹里面创建一个mongod.log文件
启动mongoDB
在bin文件夹下面运行命令行工具
在该命令行输入mongod.exe --dbpath F:\MongoDB\data\db 启动服务
默认端口:27017
确认是否服务已启动
在bin目录下 输入cmd启动命令行在输入mongo.exe --port 27017
下载compass 进入该网址https://www.mongodb.com/products/compass
下载完成安装好
如果连接出现问题,可以在F:\MongoDB\data\里,把mongod.lock删除,重启试试
使用命令行操作
在bin目录下 输入cmd启动命令行在输入mongo.exe --port 27017
show dbs 显示所有的数据库
use myblog 如果没有会直接创并切换到当前的数据库
show collections 显示当前数据库的所有集合
插入一条新数据
db.blogs.inser("title":"标题A","content":"内容A","author":"zhangsan")
查询数据
db.blogs.find()
修改一条数据
db.blogs.update({"author":"zhangsan"},{$set{"title":"标题AA"}})
删除一条数据
db.blogs.remove( json格式的条件)
查询结果倒叙排列
db.blogs.find().sort({_id:-1})
mongodb几个重要数据概念
bson = binary JSON即二进制类型的JSON
nosql = 不需要学习sql语句
node中使用mongodb (不常用,最基本的底层的连接数据库)
npm i mongodb --save
日常中常用的工具mongoose
schema和model
mongoose可提供规范
schema定义数据格式的规范
以Model规范Collection
规范数据操作的API
安装mongoose npm i mongoose --save