当前位置:网站首页>基于.NetCore开发博客项目 StarBlog - (1) 为什么需要自己写一个博客?
基于.NetCore开发博客项目 StarBlog - (1) 为什么需要自己写一个博客?
2022-04-23 03:02:00 【dotNET跨平台】
前言
OK,我也来造轮子了
博客系统从一开始用WordPress,再到后来用hexo、hugo之类的静态博客生成放github托管,一直在折腾
折腾是为了更好解决问题,最终还是打算自己花时间搞一个好了
本系列文章将记录博客的开发过程~ 将会持续更新,欢迎关注~
后端基于最新的.Net6
和Asp.Net Core
框架,遵循RESTFul接口规范,前端基于Vue
+ElementUI
开发,可作为 .Net Core 入门项目学习~
博客项目的开发已经基本完成,项目代码完全开源,点击原文可以查看项目地址,有兴趣的同学欢迎star/fork~
为啥要自己开发博客
找不到一个让我满意的在线博客
在线写博客体验不如在本地用typora写
写公众号推文的话注意力会分散一部分到如何写得吸引读者而不是文章本身
自己的网站才有完整的控制权,不会被垃圾平台添加不良信息污染
整体设计
虽然博客没啥技术含量,但还是要说一下我的想法
前面说到自己开发博客的原因有一点是我喜欢在本地用typora写博客,但markdown作为一种纯文本文件,有一个短板就是图片资源,无论是使用图床还是链接到本地,在发布的时候都有一定的麻烦。
图床可能失效,我还是习惯把资源放在本地可以自己掌握,但放在本地的话,要发布到博客园、公众号这类平台就免不了要一张张上传图片,很麻烦。
静态博客生成器可以把markdown转换成HTML然后放在github或者gitee托管,但前者国内几乎没法访问,后者自定义域名需要付费,加上现在管控严格,已经没法开启gitee pages了…
结合上述,我开发的博客最核心的一点就是要支持本地的markdown以及本地图片,要原封不动的利用我现有的几百个markdown文档来构建一个博客。
我不想做一个静态博客生成器,限制太大了,而且很多功能例如评论互动、更新推送等没办直接支持。
所以思路已经很明确了,这个博客需要读取本地的markdown文档,在不修改原有文档的基础上,将文档内容导入数据库中,同时收集文档里的资源文件(图片)。
然后博客前台为了更好的SEO效果,而且也很简单,使用后端渲染技术,不需要前后端分离;
博客数据都存储在数据库里,当然需要一个管理后台,这个后台就做成前后端分离的单页应用好了。
PS: 本来只考虑本地写完上传,后面又加了在线编辑功能,可以满足基本的文章编辑功能,体验还行
功能要求
所以总结下来,本项目开发的博客需要具备以下功能:
本地markdown文章批量上传导入,根据目录结构解析文章分类(支持多级分类嵌套),解析markdown中的图片并导入到网站目录中
本地摄影作品批量上传,读取图片EXIF信息并导入
可以配置的博客主页(展示置顶和置顶的文章、图片、分类)
代码片段编辑与分享功能
后台需要完整的文章、分类、图片、代码片段编辑功能
博客前台需要有将文章快捷发表到微信公众号、知乎专栏、博客园、掘金等平台的功能
OK,大概就这些了~ 更多功能可能后面想到了就加上~
技术选型
后端本来Django是最佳选择,自带管理后台,开发这类CMS系统最合适不过了。
然而我最近C#写得很顺手,也一直在学习AspNetCore这个高性能的web框架,觉得挺好用的,造轮子不能用太简单的工具来造,不然就失去挑战性也学不到太多新东西了… 于是就确定是AspNetCore了
前端选择之前用过的vue,前端技术栈除了不久前学了一点React之外就没怎么更新,所以先凑合一下快速实现,后面再考虑用blazor或者flutter之类好玩的新技术来重构~
所以很明确了
后端:C# + AspNetCore
ORM:FreeSQL
博客前台:Bootstrap + Vue + editor.md + bootswatch
管理端:Vue + Vuex + VueRouter
管理端UI:SCSS + ElementUI
博客截图
放几个截图咯
博客主页

文章列表

摄影页面(虽然现在还没把拍的照片放上去就是了)

管理后台主页

后台文章列表

文章编辑界面

后台图片列表

篇幅关系就放这些图片了~
博客马上就部署上线了,到时直接上demo链接!
版权声明
本文为[dotNET跨平台]所创,转载请带上原文链接,感谢
https://blog.csdn.net/sd7o95o/article/details/124287005
边栏推荐
- Difference between relative path and absolute path (often asked in interview)
- Chapter VII project communication management of information system project manager summary
- tf. keras. layers. MaxPooling? D function
- L2-006 樹的遍曆(中後序確定二叉樹&層序遍曆)
- Golden nine silver ten interview season, you are welcome to take away the interview questions (with detailed answer analysis)
- HLS / chisel uses CORDIC hyperbolic system to realize square root calculation
- Q-Learning & Sarsa
- 《信息系统项目管理师总结》第五章 项目质量管理
- tf. keras. layers. Inputlayer function
- VirtualBox virtual machine (Oracle VM)
猜你喜欢
Android 高阶面试必问:全局业务和项目的架构设计与重构
First knowledge of C language ~ branch statements
ele之Table表格的封装
Solve the problem that PowerShell mining occupies 100% of cpu7 in win7
Source code and some understanding of employee management system based on polymorphism
Encapsulate components such as pull-down menu based on ele
The input of El input input box is invalid, and error in data(): "referenceerror: El is not defined“
ROP Emporium x86_ 64 7 ~ 8 questions
C# WPF UI框架MahApps切换主题
Deep q-network (dqn)
随机推荐
SQL statement - DDL
基于多态的职工管理系统源码与一些理解
第46届ICPC亚洲区域赛(昆明) B Blocks(容斥+子集和DP+期望DP)
[learn junit5 from official documents] [II] [writingtests] [learning notes]
Traversée de l'arbre L2 - 006
.Net Core 限流控制-AspNetCoreRateLimit
The interface request takes too long. Jstack observes the lock holding
ele之Table表格的封装
Regular object type conversion tool - Common DOM class
樹莓派開發筆記(十二):入手研華ADVANTECH工控樹莓派UNO-220套件(一):介紹和運行系統
Codeforces round 784 (Div. 4) (a - H)
BLDC double closed loop (speed PI + current PI) Simulink simulation model
eventBus
Golden nine silver ten interview season, you are welcome to take away the interview questions (with detailed answer analysis)
Traversal of l2-006 tree (middle and later order determination binary tree & sequence traversal)
AC & A2C & A3C
Niuke white moon race 6 [solution]
Assembly learning Chapter III of assembly language (Third Edition) written by Wang Shuang
c#可变参数params的介绍
Jz76 delete duplicate nodes in linked list