template包(html/template)實現了數據驅動的模板,用於生成可對抗代碼注入的安全HTML輸出。本包提供了和text/template包相同的接口,不管什麼時候當輸出是HTML的時候都應使用本包。html
main.go安全
package main import ( "html/template" "io/ioutil" "os" "time" "fmt" ) func main() { t := template.New("第一個模板").Delims("[[", "]]") //建立一個模板,設置模板邊界 t, _ = t.Parse("hello,[[.UserName]]\n") //解析模板文件 data := map[string]interface{}{"UserName": template.HTML("<script>alert('you have been pwned')</script>")} t.Execute(os.Stdout, data) //執行模板的merger操做,並輸出到控制檯 t2 := template.New("新的模板") //建立模板 t2.Funcs(map[string]interface{}{"tihuan": tihuan}) //向模板中注入函數 bytes, _ := ioutil.ReadFile("test2.html") //讀文件 template.Must(t2.Parse(string(bytes))) //將字符串讀做模板 t2.Execute(os.Stdout, map[string]interface{}{"UserName": "你好世界"}) fmt.Println("\n", t2.Name(), "\n") t3, _ := template.ParseFiles("test1.html") //將一個文件讀做模板 t3.Execute(os.Stdout, data) fmt.Println(t3.Name(), "\n") //模板名稱 t4, _ := template.ParseGlob("test1.html") //將一個文件讀做模板 t4.Execute(os.Stdout, data) fmt.Println(t4.Name()) } //注入模板的函數 func tihuan(str string) string { return str + "-------" + time.Now().Format("2006-01-02") }
test1.html函數
<!DOCTYPE html> <html> <head> <title>template</title> </head> <body> hello {{.UserName}}<br> </body> </html>
test2.htmlthis
<!DOCTYPE html> <html> <head> <title>template</title> </head> <body> hello {{.UserName}}<br> {{tihuan .UserName}} </body> </html>
模版解析spa
// 模版解析 func (this *YulanController) parseTemplate(tplname string, data interface{}) (string, error) { var html string b, err := ioutil.ReadFile(tplname) if err != nil { fmt.Println(tplname, err) return "", err } t := template.New(tplname) template.Must(t.Parse(string(b))) wr := bytes.NewBufferString("") err = t.Execute(wr, data) if err != nil { fmt.Println(err) return "", err } return wr.String(), err }