【.NET项目分享】免费开源的静态博客生成工具EasyBlog,5分钟拥有自己的博客
EasyBlog 说明
本博客系统通过构建工具生成纯静态的博客网站,借助GitHub Pages,你可以在5分钟内免费拥有个人博客。 它具有以下特点
- 生成纯静态网站,访问速度极快
- 使用markdown格式来编写博客内容
- 基于git代码管理来存储你的博客
- 使用CI工具来自动化部署你的博客站点
效果展示:NilTor's Blog
️功能
- 主页博客列表,支持搜索和分类和存档筛选
- 自定义网站名称和说明
- 随系统变化的Light和Dark主题
- 移动端的自适应显示
- TOC支持
- mermaid,nomnoml,Math的渲染支持
- 代码高亮及复制支持
使用Github Page部署
Fork并配置GitHub Page
- 点击
Fork按钮,并创建自己的仓库。 并取消选择 Copy the main branch only。 - 进入自己的GitHub仓库,点击
Actions,启用workflows。 - 点击
Settings,找到Pages配置,在Build and deployment 选项中选择GitHub Actions.
配置
你可以通过根目录下的webinfo.json,对博客基础信息进行配置,如下所示:
{
"Name": "Niltor Blog", // 博客名称,显示在主页顶部导航
"Description": " for freedom",// 说明,显示在主页顶部中间
"AuthorName": "Ater", // 作者名称,显示在博客列表
"BaseHref": "/blazor-blog/", // 子目录
"Domain": "https://aterdev.github.io" // 域名,生成sitemap使用,不生成则留空
}
当你使用Github Page或使用IIS子应用部署时,需要调整BaseHref。通常是你的项目名称或子目录名。
[!IMPORTANT]
注意,BaseHref尾部的/是必需的。如果你配置了自定义域名,并且没有使用子目录,请将BaseHref设置为
/。
修改后提交代码,GitHub会触发Action自动构建。
编写博客
请使用任何你习惯的markdown编辑器编写博客,唯一的要求是将博客内容放到Content目录下。你可以在该目录下创建多级目录。
发布博客
你只需要正常提交代码即可,github action会自动构建并最终发布你的博客,发布成功后可打开您的 GitHub Page 查看。
部署到其他服务
如果你不使用Github Page,那么你也可以轻松的部署到其他服务。核心的步骤只需要两步。
生成静态内容
BuildSite项目是用来将markdown转换成html的,请在根目录执行:
dotnet run --project .\src\BuildSite\ .\Content .\WebApp Production
其中.\Content是你的markdown存储目录,.\WebApp是生成的静态站点目录。
上传到你的服务器
将WebApp中的所有文件复制到你的服务器即可。
[!TIP]
根目录下的publishToLocal.ps1脚本可以自动完成构建和生成的操作,最终内容将在根目录下WebApp目录中。如果你使用自动化部署,可参考.github/workflows中的脚本。
更新
上游代码的更新以dev分支为准,你可以将dev分支合并到你的dev分支,以获取最新的代码更新。
main作为默认的构建发布的分支,请不要合并到你的main分支。
建议您使用dev或其他自己的分支来编写博客和自定义内容,然后再合并到main分支以触发自动构建。
二次开发
fork之后,你将拥有所有的自定义权限,因为所有的源代码都已经在你自己的仓库中。
核心项目为BuildSite,用来生成静态文件,其中包括将markdown文件转换成html文件。
[!NOTE]
建议创建自己的分支来自定义开发内容,方便后续的合并。
开发环境
BuildSite项目是一个.NET项目,你需要安装.NET SDK 8.0。
此外,你可以安装(可选)
- http-server,用来启动本地静态内容,以便调试。
- tailwindcss,用来生成css样式内容。
- typescript,以便使用
tsc命令。
运行项目
- 预览项目
- 打开终端,在
WebApp目录下执行http-server,然后在浏览器中打开http://127.0.0.1:8080。
- 打开终端,在
- 生成静态内容。
- 在根目录下执行
dotnet run --project ./src/BuildSite ./Content ./WebApp,以生成最新的静态内容。 - 或者直接运行根目录下的
build.ps1脚本。
- 在根目录下执行
- 刷新浏览器,可看到最新生成的内容。
[!TIP]
如果你使用Tailwindcss,可在WebApp下执行npx tailwindcss -o ./css/app.css --watch。如果你使用
Typescript,可在WebApp下执行tsc -w。
自定义主页内容
主页内容模板位于src\BuildSite\template\index.html.tpl,其中包括以下变量:
| 模板变量 | 说明 |
|---|---|
| @ | 基础路径 |
| @ | 博客名称 |
| @ | 描述 |
| @ | 博客列表 |
| @ | 侧边栏内容:分类和存档 |
你可以按照自己的想法修改主页的布局和样式。
[!NOTE]
请注意标签中的id属性,js脚本将依赖于这些id标识,如果你修改了这些标识,同时要修改js脚本。
主页内容包括博客的搜索和分类筛选功能,其功能代码在WebApp\js\index.js中。
关于博客列表和分类列表的自定义,你可以参考BuildSite项目中HtmlBuilder.cs文件中的GenBlogListHtml和GenSiderBar方法。
后续我们会提供更灵活的自定义方式。
自定义博客展示页
博客页内容模板位于src\BuildSite\template\blog.html.tpl,其中包括以下变量:
| 模板变量 | 说明 |
|---|---|
| @ | 基础路径 |
| @ | 页面标题 |
| @ | 博客内容 |
| @ | 二级标题TOC |
关于博客展示页的内容,你可以通过WebApp/css/markdown.css来修改样式,以及WebApp/js/markdown.js来定义逻辑。
自定义代码高亮
本项目使用ColorCode来格式化markdown中的代码内容,ColorCode使用正则来匹配代码内容。如果你需要对代码高亮进行定义,你需要:
- 添加或修改正则规则,你将在
ColorCode.Core/Compilation/Languages目录下找到相应的语言定义,如果不存在,你可以添加新的语言支持。 - 如果是新添加的语言,需要在
ColorCode.Core/Languages.cs中加载该语言。
[!IMPORTANT]
如果你修改了BuildSite项目上中的代码,需要重新生成静态网站,才能看到最新效果。
【.NET项目分享】免费开源的静态博客生成工具EasyBlog,5分钟拥有自己的博客的更多相关文章
- 微软开源全新的文档生成工具DocFX
微软放弃Sandcastle有些年头了,微软最近开源了全新的文档生成工具DocFX,目前支持C#和VB,类似JSDoc或Sphinx,可以从源代码中提取注释生成文档之外,而且还有语法支持你加入其他的文 ...
- 分享一个开源的windows安卓投屏工具,scrcpy
看到scrcpy可能很多人会以为是大名鼎鼎的Scrcpy(一个十分强大的多线路爬虫框架),sorry今天分享的主角不是他,而是他: github地址:https://github.com/Genymo ...
- 永久免费开源的卫星地形图地图下载工具更新Somap2.13版本功能更新 更新时间2019年2月22日13:59:05
一.下载地址 最新版本下载地址:SoMap2.13点击此处下载 二.系统自主开发特色功能展示 1.上百种地图随意下载 高德.百度.arcgis.谷歌.bing.海图.腾讯.Openstreet.天地 ...
- 开源:C# 代码自动生成工具,支持站点前后台
前言 写这个项目有很长一段时间了,期间也修修改改,写到最后,自己也没咋用(研究方向变化了). 正文 具体项目开源了:https://github.com/supperlitt/WebAutoCodeO ...
- 免费开源的android项目分享
免费开源的android项目分享:http://yun.baidu.com/share/link?shareid=2945649048&uk=3910054188
- 开源项目福利-github开源项目免费使用Azure PipeLine
微软收购Github后,很多人猜想微软可能会砍掉VSTS,然而事实VSTS并没有砍掉,关于Azure Devops的详细信息可以查看 这篇博客,如果想查看原文也可以从链接里提供的原始地址里查看. 今天 ...
- 讲解开源项目:5分钟搭建私人Java博客系统
本文适合刚学习完 Java 语言基础的人群,跟着本文可了解和运行 Tale 项目.示例均在 Windows 操作系统下演示 本文作者:HelloGitHub-秦人 HelloGitHub 推出的< ...
- 分享一个开源免费、目前最好的API接口管理平台----eoLinker
一.概况 eoLinker 是目前业内领先.国内最大的在线 API 接口管理平台,提供自动生成 API 文档.API 自动化测试.Mock 测试.团队协作等功能,旨在解决由于前后端分离导致的开发效率低 ...
- 我们是如何通过全球第一免费开源ERP Odoo做到项目100%交付
传统友商ERP的交付过程 一.先初步需求调研,后选型功能模块 传统友商ERP第一件事情先对客户方进行初步的调研,客户方无论说什么,友商听过算过,只关心你人数多少,有哪些人涉及到哪些模块,接着对模块进行 ...
- 全球第一免费开源ERP Odoo Ubuntu最佳开发环境独家首发分享
起源 近年来随着国内的互联网经济的快速腾飞,诞生了很多开源软件创造的市场价值以及企业价值神话,特别是对于企业ERP领域,一直以来都是高昂的国内外产品充实,国内的中小成长型企业越来越需要一套好看又能打, ...
随机推荐
- MCM箱模型建模方法及大气O3来源解析
OBM箱模型可用于模拟光化学污染的发生.演变过程,研究臭氧的生成机制和进行敏感性分析,探讨前体物的排放对光化学污染的影响.箱模型通常由化学机理.物理过程.初始条件.输入和输出模块构成,化学机理是其核心 ...
- 14款DevOps/SRE工具,助力提升运维效率
简介 随着平台工程的兴起,DevOps 和 SRE 不断发展,带来了新一代工具,旨在提高软件开发和运维的效率.可扩展性和可靠性. 在本篇文章中,我们将深入探讨一些最具发展前景的工具,它们正在塑造持续集 ...
- openGauss Cluster Manager RTO Test
一.环境介绍 软件环境 类别 版本 下载链接 备注 OS openEuler 20.03 (LTS) https://repo.openeuler.org/openEuler-20.03-LTS/IS ...
- Java:得到指定年份、月份、周次的最后一天
使用Java的工具类Calendar 通过Calendar可以进行很多的日期操作 /** * 得到指定年份的最后一天 * @param year */ public static void getLa ...
- chrome浏览器代理插件SwitchyOmega使用
第一步:下载SwitchyOmega插件 Proxy_SwitchyOmega_2.5.21.crx 第二步:安装插件, 1,在chrome扩展程序开启开发者模式: 2,将插件拖过来: 第三步:设置代 ...
- Kotlin 使用协程编写高效的并发程序
概念: 轻量级的线程 协程允许我们在单线程模式下模拟多线程编程的效果,代码执行时的挂起与恢复完 全是由编程语言来控制的,和操作系统无关.这种特性使得高并发程序的运行效率得到了极大的提升. 依赖库: d ...
- 力扣290(java)-单词规律(简单)
题目: 给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律. 这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 s 中的每个非空单词之间存在着双向连接 ...
- 涨姿势 | 一文读懂备受大厂青睐的ClickHouse高性能列存核心原理
简介: 本文尝试解读ClickHouse存储层的设计与实现,剖析它的性能奥妙 作者:和君 引言 ClickHouse是近年来备受关注的开源列式数据库,主要用于数据分析(OLAP)领域.目前国内各个大厂 ...
- OpenTelemetry 简析
简介: OpenTelemetry 是 CNCF 的一个可观测性项目,旨在提供可观测性领域的标准化方案,解决观测数据的数据模型.采集.处理.导出等的标准化问题,提供与三方 vendor 无关的服务. ...
- Dubbo-Admin 正式支持 3.0 服务治理
简介:Dubbo 相信大家并不陌生,是一款微服务开发框架,它提供了 RPC 通信与微服务治理两大关键能力.大家在日常开发中更多使用的是 Dubbo 提供的 RPC 通信这一部分能力,而对其提供的服务 ...