iBlog Config WalkThrough ! iBlog 完全配置指南 !

原创
2021/08/30 00:01
阅读数 50

怀旧系列。


最近在GitHub中发现了2017年写的一个博客网站项目(目前已经删除),经过一番修改,终于能跑起来了(目的是做最后的截图留念),长这个样子的:



左边有我的各个社交媒体的主页,虽然都不怎么维护了。网站有暗黑模式和白天模式,默认是暗黑模式,保护眼睛。上面还有搜索框,支持标签搜索、正则表达式。头像是一只古代牧羊犬。



页脚的年份2021因为是计算出来的最新年份,早在2018年就不维护这个博客了。居然还可以播放BGM,我瞅了一眼仓库,发现可以选择如下2个音频文件可选,都是当年爱听的歌:


  • Up&Up (Radio Edit) - Coldplay.mp3

  • Blank Space - Taylor Swift.mp3



点击About,还能弹出自我介绍:


可以看出,我当年的文笔很有嘻哈、无厘头风格,可能是受大学室友的影响,觉得这样“不说人话”的样子很酷。。。至于这个jinhengyu.xyz本来想好好维护的,后来种种原因就放弃了。


图中提到的前身OpenBlog也是我写的博客框架,当年超喜欢研究博客,写博客完全是出于自嗨,所以粉丝数寥寥,关于OpenBlog可以看看这2篇文章:



这个博客最大的特色是,所有文章都是其他平台的链接,博客本身不存储文章,只存储每篇文章的元信息:标题、url、内容概括、原创性、标签、发表日期、图片。比如下面这个JSON:


{    "title": "10个实用技巧,让Finder带你飞~",    "url": "https://yq.aliyun.com/articles/307497",    "desc": "Finder 是 Mac 电脑的系统程序,有的功能类似 Windows 的资源管理器。它是我们打开 Mac 首先见到的「笑脸」,有了它,我们可以组织和使用 Mac 里的几乎所有东西,包括应用程序、文件、文件夹、磁盘以及你网络上的共享磁盘,你同时可以通过它看到丰富的、高质量的文件预览。",    "copy": false,    "tags": ["mac", "2016", "finder"],    "date": 1475901420000,    "img": ""}


然后将所有JSON存到mongodb数据库中,原以为通过日积月累,坚持录入新文章,文章可以越来越多,形成自己的笔记仓库,可以快速检索以前写过的任何东西,可是最终只坚持到第9篇就放弃了,这9篇文章是:







下面就展示一些博客的源文件了(乱七八糟)


博客的README.md


iBlog Config WalkThrough ! iBlog 完全配置指南 !

Intro

...iBlog诞生于 Sat Sep 02 2017, 前身是OpenBlog, 前后端分离之后网站挂了...多年后发现一些第三方博客平台如CSDN和OSChina还留着以前写的许多辣鸡文章, 为何不做一个平台把他们链接起来呢? 于是我利用XXXX的时间完成了这个轻量级博客(600K+), 当前版本 1.0.3, 特别感谢MDUI框架提供了响应式的Material风格 ~

About Author

目前是个缺钱的noder, 未来可能是个denor, 一生专注Web全栈, 走得很安详... 意淫的个人tags: ["JinHengyu","Jim","恒星","智障"]... 常用邮箱 jinhengyu666@qq.com 终身域名 jinhengyu.xyz, 服务器目前在米国所以略慢(反正没人看)

Environment

数据库: mongodb 4.0.3 容器: expressjs 4.16.2 前端: mdui 0.4.1

以上3个主要框架, 还有一些小的模块详见package.json, 除此之外无任何依赖, 初次访问600+K, 缓存之后~50K [流量天使]

Config

Keywords

  • linked: 博客原名叫LinkedBlog, 原因是本博客不存储文章内容, 全部链接于第三方站点, MongoDB只存储每篇文章的元数据(meta data)

  • secure: 减少了文章存储的设计成本, 我将更多的经历投入到网站安全设计上, 做到99%的安全

  • single-user: 网站用户(不是访客)唯一, 是一个单人博客

  • light-weight: 初始响应体积600K+, 缓存后每次不到100K, 依赖极少

  • read-only: 访客(guest)只可读, 意味着没有点赞和访问量的统计数据, 一定程度上增强安全性

  • material-design: 全站遵守material design设计原则, 实现无缝的动态UI, 感谢MDUI框架(https://mdui.org)

  • responsive: 响应手机端/平板/laptop三种屏幕以及更大的屏幕

常用命令(表达式)

统计post目录中json文件数量:

require('fs').readdir(cfg.post.path).filter(f=>f[0]!=='.').length 统计mongo中post表中文章数量:


网站上所有的图片:





package.json:


{  "name": "iblog",  "description": "iblog",  "main": "index.js",  "scripts": {    "test": "istanbul cover _mocha",    "start": "pm2 start index.js --name 'iblog'"  },  "author": "JinHengyu",  "license": "MIT",  "dependencies": {    "archiver": "^3.0.0",    "body-parser": "^1.18.3",    "connect-mongo": "^2.0.1",    "ejs": "^2.5.7",    "express": "^4.16.2",    "express-session": "^1.15.6",    "mongodb": "^3.1.8"  },  "devDependencies": {}}


本文分享自微信公众号 - WebHub(myWebHub)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

展开阅读全文
加载中

作者的其它热门文章

打赏
0
0 收藏
分享
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部