如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

技术架构和实现方案

为了降低大家的使用和部署成本, 我们采用了如下技术实现:

  • 服务层: koa2 + nodejs + jsonSchema(当然其中还使用了很多nodejs中间件)

  • 前台页面: pug(结合nodejs实现前后端同构, 且天然的SSR)

  • 后台管理: umi3.0 + react + antd + axios + typescript(当然还用了很多前端插件, 比如富文本,  md编辑器)

  • 系统/服务器相关: linux / pm2 / nginx

基本架构模式如下图所示:

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

系统页面架构图:

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

功能分析

接下来笔者就来介绍 simpleCMS 的功能点. 我们先来分析一下后台管理系统.

后台管理系统功能分析

后台管理系统是动态博客系统必备的模块, 它能很方便的管理我们的网站数据. 这里笔者先来带大家看一下后台管理系统的基本模块:

  • 登录页面

  • 数据大盘

  • 内容管理

  • 页面配置

  • 广告配置

  • 用户信息管理

  • 多语言支持

以上是 cms 管理系统必备的模块, 这里我们基本上采用react hooks 来写, 具体页面如下:

1 登录页面

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

2 数据大盘

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

3 文章管理

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

4 内容编辑

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

5 多语言支持

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

其他页面就不一一展示了, 感兴趣的朋友可以体验一下. 主要技术采用 umi + antd + react + typescript 实现, 感兴趣可以在  github 上参考学习.

前台基本功能分析

前台主要是我们的博客网站, 这里采用 pug 这个模版引擎来实现, 交互功能使用大家最熟悉的jquery.前台基本模块有:

  • 博客首页

  • 文章列表页

  • 文章详情页

对应的交互功能有点赞, 评论, 文章搜索功能等, 基本页面如下:

1 首页

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

2 列表页

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

3 详情页

 如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

4 评论和点赞

 如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

由于pug模版引擎适合做一些展示型的网站, 所以非常适合用在cms系统中, 我们也可以使用ejs等模版引擎.

技术实现细节

由于整个cms 系统是一个完整的技术闭环, 数据流转都是相关的, 这里笔者主要总结一下实现一个cms的技术细节.

  • 数据统计功能实现 —— 采用nodejs定时任务(node-schedule)

  • 富文本和md编辑器实现

  • 后台多语言实现方案

  • 内容管理流程设计

  • pug 模版和数据交互

  • jsonSchema 数据结构设计

  • 手写简单加密解密算法

  • 跨域解决方案以及用户权限设计

  • pm2管理node进程以及做负载均衡

  • 多进程场景下的并发锁设计

数据统计功能实现

数据统计主要是统计网站的pv, 单篇文章阅读量和点赞量, 为了更好的进行分析我们需要对单日的数据进行统计和存库,  具体实现就是利用定时任务在一天结束前进行数据的统计, 这里我们用 node-schedule来实现, 具体使用方式笔者也在之前的文章中做了介绍,  感兴趣可以参考一下.

如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

基本使用如下:

let schedule = require('node-schedule');  let testJob = schedule.scheduleJob('42 * * * *', function(){   console.log('将在未来的每个时刻的42分时执行此代码, 比如22:42, 23:42'); });

富文本和md编辑器方案实现

这里我们用的富文本组件是braft, 功能和可扩展性基本满足业务需求, md编辑器是程序员写博客的基本方式, 这里主要采用了for-editor,  其次就是对其进行了二次封装来实现支持剪切板功能.

国际化方案

多语言主要使用的react-intl, 由于umi 对其有很好的集成, 所以说我们只需要搭建基本的多语言规则即可.  比如在项目目录里建立locales文件夹, 然后存放zh(中文)/en(英文)文件即可, 基本的代码如下:

// locales/en/user export default {   simpleCMS_DESC: 'Easy to use CMS system, help everyone to have their own website blog.',   CopyrightText: 'SimpleCMS r&d team', }  // locales/zh/user export default {   simpleCMS_DESC: '简单易用的cms系统, 助力每个人都能拥有自己的网站博客。',   CopyrightText: 'SimpleCMS 研发团队' }

原创文章,作者:MMLVO,如若转载,请注明出处:http://www.wangzhanshi.com/n/18217.html

(0)
MMLVO的头像MMLVO
上一篇 2025年1月2日 12:48:36
下一篇 2025年1月2日 12:48:38

相关推荐

发表回复

登录后才能评论