千家信息网

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

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章主要讲解了"如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何从零打造一款
千家信息网最后更新 2025年01月20日如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS

这篇文章主要讲解了"如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS"吧!

技术架构和实现方案

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

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

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

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

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

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


系统页面架构图:


功能分析

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

后台管理系统功能分析

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

  • 登录页面

  • 数据大盘

  • 内容管理

  • 页面配置

  • 广告配置

  • 用户信息管理

  • 多语言支持

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

1 登录页面


2 数据大盘


3 文章管理


4 内容编辑


5 多语言支持


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

前台基本功能分析

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

  • 博客首页

  • 文章列表页

  • 文章详情页

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

1 首页


2 列表页


3 详情页

4 评论和点赞

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

技术实现细节

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

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

  • 富文本和md编辑器实现

  • 后台多语言实现方案

  • 内容管理流程设计

  • pug 模版和数据交互

  • jsonSchema 数据结构设计

  • 手写简单加密解密算法

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

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

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

数据统计功能实现

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


基本使用如下:

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 研发团队' }

感谢各位的阅读,以上就是"如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS"的内容了,经过本文的学习后,相信大家对如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

0