diff --git a/conf/app.yml b/conf/app.yml
index 3f09d78..6d4fa37 100644
--- a/conf/app.yml
+++ b/conf/app.yml
@@ -24,6 +24,7 @@ blogapp:
length: 400 # 自动截取预览, 字符数
trash: -48 # 回收箱保留48小时
clean: 1 # 定时清理回收箱,每 %d 小时
+ timezone: Asia/Shanghai # 时区
disqus: # 评论相关
shortname: xxxxxx
publickey: wdSgxRm9rdGAlLKFcFdToBe3GT4SibmV7Y8EjJQ0r4GWXeKtxpopMAeIeoI2dTEg
@@ -56,4 +57,4 @@ blogapp:
backupapp:
name: cmd-backup
enablehttp: true
- httpport: 9000
+ httpport: 9001
diff --git a/pkg/cache/cache.go b/pkg/cache/cache.go
index d94c951..b40572a 100644
--- a/pkg/cache/cache.go
+++ b/pkg/cache/cache.go
@@ -32,6 +32,14 @@ var (
)
func init() {
+ // init timezone
+ var err error
+ tools.TimeLocation, err = time.LoadLocation(
+ config.Conf.BlogApp.General.Timezone)
+ if err != nil {
+ panic(err)
+ }
+ // init store
store, err := store.NewStore(config.Conf.Database.Driver,
config.Conf.Database.Source)
if err != nil {
@@ -514,23 +522,25 @@ func (c *Cache) regeneratePages() {
gt12Month = len(Ei.Archives) > 12
)
for _, archive := range c.Archives {
+ t := archive.Time.In(tools.TimeLocation)
if gt12Month {
- year := archive.Time.Format("2006 年")
+ year := t.Format("2006 年")
if currentYear != year {
currentYear = year
- buf.WriteString(fmt.Sprintf("\n### %s\n\n", archive.Time.Format("2006 年")))
+ buf.WriteString(fmt.Sprintf("\n### %s\n\n", t.Format("2006 年")))
}
} else {
- buf.WriteString(fmt.Sprintf("\n### %s\n\n", archive.Time.Format("2006年1月")))
+ buf.WriteString(fmt.Sprintf("\n### %s\n\n", t.Format("2006年1月")))
}
for i, article := range archive.Articles {
+ createdAt := article.CreatedAt.In(time.Location)
if i == 0 && gt12Month {
str := fmt.Sprintf(`* *[%s](/post/%s.html) (%s)`,
- article.Title, article.Slug, article.CreatedAt.Format("Jan 02, 2006"))
+ article.Title, article.Slug, createdAt.Format("Jan 02, 2006"))
buf.WriteString(str)
} else {
str := fmt.Sprintf(`* [%s](/post/%s.html) (%s)`,
- article.Title, article.Slug, article.CreatedAt.Format("Jan 02, 2006"))
+ article.Title, article.Slug, createdAt.Format("Jan 02, 2006"))
buf.WriteString(str)
}
buf.WriteByte('\n')
diff --git a/pkg/config/config.go b/pkg/config/config.go
index 7337b14..332818c 100644
--- a/pkg/config/config.go
+++ b/pkg/config/config.go
@@ -48,6 +48,7 @@ type General struct {
Length int `yaml:"length"` // 文章预览长度
Trash int `yaml:"trash"` // 回收箱文章保留时间
Clean int `yaml:"clean"` // 清理回收箱频率
+ Timezone string `yaml:"timezone"` // 时区
}
// Disqus comments
diff --git a/pkg/core/blog/admin/admin.go b/pkg/core/blog/admin/admin.go
index b861b38..a40a9bc 100644
--- a/pkg/core/blog/admin/admin.go
+++ b/pkg/core/blog/admin/admin.go
@@ -227,13 +227,14 @@ func handleAPIPostCreate(c *gin.Context) {
cid int
)
defer func() {
+ now := time.Now().In(tools.TimeLocation)
switch do {
case "auto": // 自动保存
if err != nil {
- c.JSON(http.StatusOK, gin.H{"fail": 1, "time": time.Now().Format("15:04:05 PM"), "cid": cid})
+ c.JSON(http.StatusOK, gin.H{"fail": 1, "time": now.Format("15:04:05 PM"), "cid": cid})
return
}
- c.JSON(http.StatusOK, gin.H{"success": 0, "time": time.Now().Format("15:04:05 PM"), "cid": cid})
+ c.JSON(http.StatusOK, gin.H{"success": 0, "time": now.Format("15:04:05 PM"), "cid": cid})
case "save", "publish": // 草稿,发布
if err != nil {
responseNotice(c, NoticeNotice, err.Error(), "")
@@ -498,9 +499,9 @@ func handleAPIQiniuDelete(c *gin.Context) {
// parseLocationDate 解析日期
func parseLocationDate(date string) time.Time {
- t, err := time.ParseInLocation("2006-01-02 15:04", date, time.Local)
+ t, err := time.ParseInLocation("2006-01-02 15:04", date, tools.TimeLocation)
if err == nil {
- return t
+ return t.UTC()
}
return time.Now()
}
diff --git a/tools/tmplfunc.go b/tools/tmplfunc.go
index 6814de9..6a250c2 100644
--- a/tools/tmplfunc.go
+++ b/tools/tmplfunc.go
@@ -12,7 +12,12 @@ import (
"time"
)
-var TplFuncMap = make(template.FuncMap)
+var (
+ // TplFuncMap template func map
+ TplFuncMap = make(template.FuncMap)
+ // TimeLocation set location timezone
+ TimeLocation = time.UTC
+)
func init() {
TplFuncMap["dateformat"] = DateFormat
@@ -22,19 +27,23 @@ func init() {
TplFuncMap["getavatar"] = GetAvatar
}
+// Str2html string to html
func Str2html(raw string) htmpl.HTML {
return htmpl.HTML(raw)
}
-// DateFormat takes a time and a layout string and returns a string with the formatted date. Used by the template parser as "dateformat"
+// DateFormat takes a time and a layout string and returns a string with the formatted date.
+// Used by the template parser as "dateformat"
func DateFormat(t time.Time, layout string) string {
- return t.Format(layout)
+ return t.In(TimeLocation).Format(layout)
}
+// Join join string array with sep
func Join(a []string, sep string) string {
return strings.Join(a, sep)
}
+// IsNotZero judge t is zero
func IsNotZero(t time.Time) bool {
return !t.IsZero()
}
@@ -43,6 +52,7 @@ func IsNotZero(t time.Time) bool {
// url: https:///static/img/avatar.png
var avatar string
+// GetAvatar store avatar base64 into css
func GetAvatar(domain string) string {
if avatar == "" {
resp, err := http.Get("https://" + domain + "/static/img/avatar.png")
diff --git a/tools/tmplfunc_test.go b/tools/tmplfunc_test.go
new file mode 100644
index 0000000..a67d589
--- /dev/null
+++ b/tools/tmplfunc_test.go
@@ -0,0 +1,43 @@
+// Package tools provides ...
+package tools
+
+import (
+ "testing"
+ "time"
+)
+
+func TestDateFormat(t *testing.T) {
+ now := time.Now()
+ layout := "2006-01-02 15:04:05"
+ str := DateFormat(now, layout)
+ t.Log(str)
+
+ var err error
+ TimeLocation, err = time.LoadLocation("Asia/Shanghai")
+ if err != nil {
+ t.Fatal(err)
+ }
+ str = DateFormat(now, layout)
+ t.Log(str)
+}
+
+func TestParseInLocation(t *testing.T) {
+ date := "2021-04-27 15:33"
+ layout := "2006-01-02 15:04"
+ tm, err := time.Parse(layout, date)
+ if err != nil {
+ t.Fatal(err)
+ }
+ t.Log(tm)
+
+ TimeLocation, err = time.LoadLocation("Asia/Shanghai")
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ tm, err = time.ParseInLocation(layout, date, TimeLocation)
+ if err != nil {
+ t.Fatal(err)
+ }
+ t.Log(tm.UTC())
+}