/koa-cms

koa2定制化二次开发,koa-cms打造一个好用的异步编程模型 web框架

Primary LanguageJavaScript

koa2 打造服务端 CMS

Author: 卢珑文
Email: lulongwen@live.com
Wechat: 18915972355
Website: www.lulongwen.com
Github: www.github.com/lulongwen

koa-cms

KOA-CMS 技术栈

KOA-CMS 前后端分离的 Content Management System

独立完成一个项目,自己完整的开发一个前后端项目

  1. nodejs + npm + Koa + ES9 + Babel + Typescript + JWT
  2. mysql + navicat + RestFul API
  3. 微信开发者工具 + PostMan + nodemon + pm2
    1. nodemon 检测文件变化,自动重启 node服务
    2. cross-env 设置环境变量,兼容 mac,linux,win10
  4. 系统设计,分层思路,接口设计思路
    • 渐进式开发,在已有功能上开发新功能,不是一步到位
    • 设计,抽离,分层
    • 如何设计 server 端架构,API 和路由,数据模型设计
    • 模板路由和 API设计
  5. 服务器部署
npm i axios lodash npm-check require-directory validator sequelize
npm i basic-auth jsonwebtoken mysql2 bcryptjs
npm i koa-router koa-static koa-bodyparser

环境变量

process.env.NODE_ENV

CMS技术点

  1. validator 参数校验

    • 每个请求都有一个唯一的 validator
    • Validator中间件来构建验证层
  2. 全局异常处理中间件

    • http错误状态码
  3. 路由自动注册 require-directory

    • 路由按照主题拆分;主题划分是渐进式,先找出核心主题
    • app.js入口导入子模块;子模块不应该调用入口文件;分层次,上层调用下层
  4. Sequelize & Mysql

    • 服务端开发你是绕不过 mysql的
  5. Web分层结构

    • model service logic
  6. RestFul

    • web开发不考虑状态
    • 权限中间件

安全

  1. 身份验证 httpbasicAuth
  2. bcryptjs 密码加密
  3. XSS
  4. 真正的权限控制还是服务端,前端只是辅助展示

异常处理

  1. 全局异常捕获
  2. express内置异常处理
  3. 自定义异常处理
  4. 专门的 404异常处理 NotFound
throw new Error('自定义异常')

app.use(notFound)
app.use(errorGlobal)

参数验证

  1. GET
  2. POST

GIT

https://code.aliyun.com/groups/longwen-blog

ssh

查看本地公钥

cd ~/.ssh
ls

# 如果已经存在 id_rsa.pub 就直接打开该文件,获取到公钥
subl id_rsa.pub

# 创建公钥
ssh-keygen -t rsa -C "你的邮箱"

API

  1. 开闭原则:对修改关闭,对扩展开放
  2. 循环引用 bug,死循环;分层次,上层调用下层

KOA-CMS 目录结构

app CMS系统代码
src 业务代码
  1. CMS规范
  2. 配置 权限管理
  3. 行为日志
  4. 校验器
  5. 令牌
  6. 单元测试

koa中间件

中间件,就是可插拔的功能函数

中间件是个函数,完整的结构有:err, req, res, next -> function

  1. 异常
  2. 处理一下业务功能,然后转交控制权 next
  3. 响应请求,结束响应,当做路由的处理函数,例如参数的验证

koa内置中间件

  1. app 级别中间件,注册时,一定在最顶级使用
  2. router级别中间件
  3. 全局异常处理

第三方中间件

  1. koa-router
  2. koa-views,渲染 ejs模板
  3. koa-static,静态文件服务
    1. https://github.com/koajs/static
  4. koa-json,解析请求中的 json对象
  5. koa-bodyparser,解析 post请求的数据
  6. koa-logger,格式化日志
  7. koa-redis,连接 redis
  8. koa-generic-session,生成session
  9. koa-convert
  10. 思考各个插件的实现原理?

自定义中间件

  1. login-check,检测 api请求的登录状态
  2. login-redirect,检测请求中的登录状态
  3. validator,post请求数据的 json schema验证

nodejs 最佳实践

  1. 目录结构
  2. 全局错误处理
  3. 代码风格
  4. 质量保证
  5. 安全
  6. 线上环境
  7. 渐进式,在已有功能上开发新功能,不要一步到位
    1. 先设计,再开发,开发过程中,反复回顾设计,优化设计方案
    2. 系统设计,分层思路,接口设计思路,数据建模思路

为什么开发 KOA-CMS

  1. CMS是前后端一体化的解决方案;是一个系统不可或缺的组成部分

    • 开发大多数都是操作和管理数据,然后展示界面,拒绝重复劳动,框架解决
    • 技术的积累和进阶,拒绝搬砖
  2. 移动端主要浏览和展示数据,web端录入和管理数据,生产数据

    • 移动端数据录入的难度很大,需要放到 web端来做
    • web生产数据,多端展示数据
  3. PHP CMS 基于模板渲染的架构,不能适应前后端分离

    • 服务端模板语言生成,增加开发的复杂度和学习成本
    • 技术的边界和范围
  4. SPA适合做中后台管理系统开发,不需要 SEO

    • SEO需要 SSR服务端渲染
    • SPA开发 CMS 用户体验好
  5. 如何做好一个产品

    • 商业性的项目才能驱动进步;做出有人用的产品,做出高质量的成品项目
    • 选择小而美的公司,技术的提升,必须有复杂的业务驱动
    • 以解决问题为目标,懂得取舍,卖东西都说自己的好

服务端开发

  1. 服务稳定性
    1. 单个客户端可以意外挂掉,但服务端不能
    2. 不可用时长
    3. pm2 进程守候,服务挂掉,自动重启
  2. 考虑内存和 CPU,优化和扩展
    1. server端要承载很多请求,CPU和内存都是稀缺资源
    2. stream写日志,redis存 session,优化CPU
  3. 日志记录
    1. 记录日志,存储日志,分析日志
  4. 安全
    1. server端可能遭受各种恶意攻击和误操作
  5. 集群和服务拆分
    1. 扩展机器和服务拆分来承载大流量
  6. 编程语言从来不是问题,重要的是开发思维
    1. 开发人员,总是受限于工作职位和思维

前端进阶提升

  1. 接受即成的事实
  2. 我并不认为我的能力和编程水平,学习能力比大厂的人差在哪里
  3. 我还能做很多事情,未来有很大的进步空间
    • 能力不断提升,更多的职责,与人沟通做管理,亲自动手和实践
  4. 综合素质:交流,管理,认知,学习,任务规划
  5. 培养一个兴趣:摄影,写作,画画
  6. 前后端分离缺点:削弱了技能的进阶,扼杀了成长,必须要进阶服务端
    • 掌握服务端,统领全局
    • 拒绝原地打转,玩溜一个技术栈,比如 vue
    • 好的代码利于维护,提高编程效率
  7. 自我解决问题,寻找答案的思考过程

陈述做过的项目

  1. 你需要用尽可能简练的文字来描述项目的背景
  2. 你在项目中承担的角色、参与项目的时长
  3. 你用到的技术,以及你在项目中亮点等信息
  4. 善于归纳,一针见血地发现问题或把一个问题说清楚