什么是eggJS
Node.js的一个库,是基于koa的库
官网链接:https://eggjs.org/zh-cn/intro/quickstart.html
参考视频:https://www.bilibili.com/video/av38372787/?p=9
MVC
service(model): 模型 和数据打交道(查询数据库 请求数据等)
view:视图层 页面展示/模板
controller:控制器,负责处理一些业务逻辑
路由
传值方式:
①get传值: …/testParam?name=123
// router.js
router.get('/test', controller.home.test);
//通过 `this.ctx.query` 来获取
②动态路由: …/testParam/123
// router.js
router.get('/testParam/:id', controller.home.testParam);
// controller
// 通过 `this.ctx.params` 来获取
控制器
定义的 Controller 类,会在每一个请求访问到 server 时实例化一个全新的对象,而项目中的 Controller 类继承于 egg.Controller,会有下面几个属性挂在 this 上。
- this.ctx: 当前请求的上下文 Context 对象的实例,通过它我们可以拿到框架封装好的处理当前请求的各种便捷属性和方法。
- this.app: 当前应用 Application 对象的实例,通过它我们可以拿到框架提供的全局对象和方法。
- this.service:应用定义的 Service,通过它我们可以访问到抽象出的业务层,等价于 this.ctx.service 。
- this.config:应用运行时的配置项。
- this.logger:logger 对象,上面有四个方法(debug,info,warn,error),分别代表打印四个不同级别的日志,使用方法和效果与 context logger 中介绍的一样,但是通过这个 logger 对象记录的日志,在日志前面会加上打印该日志的文件路径,以便快速定位日志打印位置。
post提交的CSRF安全机制
- 方法一:
例如在home页面中有个表单提交:应该在渲染前加上这个字段,在post时,中间件的时候会自动校验
上面这个也可以写成下面的形式
- 方法二:在每个用户访问的时候,中间件给它设计一个全局变量
变成全局变量:
在中间件中:新建auth.js :
cookie
实现不同页面的数据共享:
this.ctx.cookie.set()
this.ctx.cookie.get()