基于 Git 的博客系统,具有以下特性:
演示地址: https://caixw.io
go get github.com/caixw/gitype
;scripts/build.sh
编译代码(也可以直接执行 go build
编译,除了版本号,并无其它差别。);gitype -init=/to/path
输出初始的数据内容;gitype -appdir=/to/path
。./scripts 目录下包含了部分平台下的转换成守护进程的脚本
./testdata 也是一个完整的工作目录,如果不想执行 -init
命令初始化的话,也可以直接复制 ./testdata 的内容。
appdir 的目录结构是固定的。 其中 conf 为程序的配置相关内容,包含了后台更新界面的密码,不能对外公开; data 为博客的实际内容,包含了文章,标签,友链以及网站名称等相关的配置, 所有针对博客内容的相关设置和内容发布,都直接体现在此目录下。
|--- conf 程序的配置文件
| |
| |--- logs.xml 日志的配置文件
| |
| |--- app.yaml 程序的配置文件
|
|--- data 程序的数据目录
|
|--- meta 博客的一些设置项
| |
| |--- config.yaml 基本设置项,比如网站名称等
| |
| |--- tags.yaml 标签的定义
| |
| |--- links.yaml 友情链接
|
|--- posts 文章所在的目录
|
|--- raws 其它可直接通过地址访问的内容可直接放在此处
|
|--- themes 自定义的主题目录
|
|--- default 默认的主题
conf 目录下的为程序级别的配置文件,需要重启才能使更改生效。其中:
名称 | 类型 | 描述 |
---|---|---|
https | bool | 是否启用 https |
httpState | string | 当 https 为 true 时,对 80 端口的处理方式,可以为 disable、redirect 和 default |
certFile | string | 当 https 为 true 时,此值为必填 |
keyFile | string | 当 https 为 true 时,此值为必填 |
port | string | 端口,不指定,默认为 80 或是 443 |
headers | map | 附加的头信息,头信息可能在其它地方被修改 |
webhook | Webhook | 与 webhook 相关的设置 |
名称 | 类型 | 描述 |
---|---|---|
url | string | webhooks 的接收地址 |
frequency | time.Duration | webhooks 的最小更新频率 |
method | string | webhooks 接收地址的接收方法,默认为 POST |
repoURL | string | 远程仓库的地址 |
涉及的时间均为 RFC3339 格式:2006-01-02T15:04:05Z07:00。
config.yaml 指定了网站的一些基本配置情况:
名称 | 类型 | 描述 |
---|---|---|
title | string | 网站标题 |
subtitle | string | 网站副标题 |
url | string | 网站的地址 |
beian | string | 备案号 |
uptime | string | 上线时间,符合 rfc 3339 标准的时间字符串 |
pageSize | int | 每页显示的数量 |
longDateFormat | string | 长时间的显示格式,Go 的时间格式化方式 |
shortDateFormat | string | 短时间的显示格式,Go 的时间格式化方式 |
theme | string | 默认主题 |
type | string | 所有 HTML 页面的 mimetype,默认使用 text/html |
icon | Icon | 网站的图标 |
menus | []Link | 菜单内容,格式与 links.yaml 的相同 |
author | Author | 文章的默认作者信息 |
license | Link | 文章的默认版权信息 |
archive | Archive | 存档页的相关配置 |
outdated | time.Duration | 超过此时间值,文章被标记为过时内容,显示一些提示信息 |
rss | RSS | rss 配置,若不需要,则不指定该值即可 |
atom | RSS | atom 配置,若不需要,则不指定该值即可 |
sitemap | Sitemap | sitemap 相关配置,若不需要,则不指定该值即可 |
opensearch | Opensearch | opensearch 相关配置,若不需要,则不指定该值即可 |
pages | map[string]Page | 各个类型页面的一些自定义项 |
名称 | 类型 | 描述 |
---|---|---|
name | string | 名称 |
url | string | 网站地址 |
string | 邮箱 | |
avatar | string | 头像 |
名称 | 类型 | 描述 |
---|---|---|
order | string | 存档的排序方式,可以是:desc(默认) 和 month |
type | string | 存档的分类方式,可以是按年:year(默认) 或是按月:month |
format | string | 标题的格式 |
名称 | 类型 | 描述 |
---|---|---|
title | string | 标题 |
size | int | 显示数量 |
url | string | 地址 |
type | string | 当前文件的 mimetype |
名称 | 类型 | 描述 |
---|---|---|
url | string | Sitemap 的地址 |
xslURL | string | 为 sitemap.xml 配置的 xsl,可以为空 |
enableTag | bool | 是否把标签放到 Sitemap 中 |
priority | float | 标签页的权重 |
changefreq | string | 标签页的修改频率 |
postPriority | float | 文章页的权重 |
postChangefreq | string | 文章页的修改频率 |
type | string | 当前文件的 mimetype,默认为 application/atom+xml 或是 applicatin/rss+xml |
名称 | 类型 | 描述 |
---|---|---|
url | string | opensearch 的地址 |
title | string | 出现于 html>head>link.title 属性中 |
shortName | string | shortName 值 |
description | string | description 值 |
longName | string | longName 值 |
image | Icon | image 值 |
type | string | 当前文件的 mimetype 若不指定,会使用 vars 包中的默认值 |
名称 | 类型 | 描述 |
---|---|---|
type | string | 图标的 mimetype |
sizes | string | 图标的大小 |
url | string | 图标地址 |
名称 | 类型 | 描述 |
---|---|---|
text | string | 字面文字,可以不唯一 |
url | string | 对应的链接地址 |
title | string | a 标签的 title 属性。可以为空 |
icon | string | 一个 URL 或是 fontawesome 图标名称 |
rel | string | a 标签的 rel 属性 |
type | string | 指向内容的类型 |
名称 | 类型 | 描述 |
---|---|---|
title | string | 页面的 html>head>title |
keywords | string | 页面的 html>head>meta.keywords |
description | string | 页面的 html>head>meta.description |
部分页面可使用 %content% 占位符,分别是表示网站名称和可自由取代的内容,比如 tag 页面,%content 会用标签名代替
tag 和 post 页面的 keywords 和 description 是不可更改的
links.yaml 用于指定友情链接,为一个数组。每个元素均为一个 Link
。
每个元素可以使用 XFN。
tags.yaml 用于指定所有的标签内容。为一个数组,每个元素包含以下字段:
名称 | 类型 | 描述 |
---|---|---|
slug | string | 唯一名称,文章引用此值,地址中也使用此值 |
title | string | 字面文字,可以不唯一 |
color | string | 颜色值,在展示所有标签的页面,会以此颜色显示 |
content | string | 用于描述该标签的详细内容,可以是 HTML |
series | bool | 是否为一个专题 |
data/posts 为文章目录,目录层次可以按自己的习惯进行分类,系统根据是否包含 meta.yaml
和 content.html
来区分当前目录是否为一篇文章内容。比如:
--- posts
+--- about
| |
| +--- meta.yaml
| |
| +--- content.html
|
+--- 2016
|
+--- 2017
|
+--- post1
| |
| +--- meta.yaml
| |
| +--- content.html
|
+--- post2
|
+--- meta.yaml
|
+--- content.html
其中 /posts/about
、/posts/2017/post2
和 /posts/2017/post2
均被判断为文章。
meta.yaml 包含了当前文章的一些细节信息。
名称 | 类型 | 描述 |
---|---|---|
title | string | 标题 |
created | string | 创建时间,符合 rfc 3339 标准的时间字符串 |
modified | string | 修改时间,符合 rfc 3339 标准的时间字符串 |
tags | string | 关联的标签,以逗号分隔多个字符串,标签名为 meta/tags.yaml 中的 slug |
summary | string | 摘要,同时也作为 html>head>meta.description 的内容 |
content | string | 内容 |
outdated | string | 已过时文章的提示信息 |
state | string | 状态,可以是 top、last、draft 和 default,默认为 default |
author | Author | 作者,默认为 meta/config.yaml 中的 author 内容 |
license | Link | 版本信息,默认为 meta/config.yaml 中的 license 内容 |
template | string | 使用的模板,默认为 post |
keywords | string | html>head>meta.keywords 标签的内容,如果为空,使用 tags |
data/themes 下为主题文件,可定义多个主题,通过 config 中的 theme 指定当前使用的主题。 主题模板语法为 html/template。
单一主题下,可以为文章详细页定义多个模板,通过每篇文章的 meta.yaml 可以自定义当前文章使用的模板, 默认情况下,使用 post 模板。
400 及以上的错误信息,均可以自定义,方式为在当前主题目录下,新建一个与错误代码相对应的 HTML 文件, 比如 400 错误,会读取 400.html 文件,以此类推。但是只能是纯 HTML 文本,不能包含模板代码。
当访问的页面不存在时,会尝试从 raws 下访问相关内容。比如 /abc.html
,会尝试在查找 raws/abc.html
文件是否存在;甚至 /post/2016/about.htm
这样标准的文章路由,如果文章不存在,会也访问 raws
目录,查看其下是否在正好相同的文件。
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。
1. 开源生态
2. 协作、人、软件
3. 评估模型