[英]http.HandleFunc invokes root handler 3 times per request
package main
import (
"fmt"
"io"
"html/template"
"net/http"
"log"
)
type pageFunc func() (string, interface{})
func thread() (string, interface{}) {
return "thread", nil
}
func main() {
t := template.New("main")
t.ParseGlob("templates/*.xhtml")
respond := func(f pageFunc) http.HandlerFunc {
fmt.Println("respond 1")
return func(w http.ResponseWriter, r *http.Request) {
fmt.Println("respond 2")
name, data := f()
t.ExecuteTemplate(w, name, data)
}
}
http.HandleFunc("/", respond(thread))
err := http.ListenAndServe(":7842", nil)
if err != nil {
log.Fatal("ListenAndServe: ", err)
}
}
啟動上述程序並將單個請求發送到http://localhost:7842/
導致控制台輸出:
respond 1
respond 2
respond 2
respond 2
如果我注釋掉,它似乎只調用一次處理程序:
name, data := f()
t.ExecuteTemplate(w, name, data)
在這種情況下,我得到:
respond 1
respond 2
這完全超出了我的理解。 調用t.ExecuteTemplate會如何導致被調用的函數多次運行? 更奇怪的是(至少對我而言),如果我像這樣稍微改變路徑,
http.HandleFunc("/a", respond(thread))
……即使模板函數未注釋,它也僅觸發處理程序函數一次。 怎么了?
有問題的模板,如果有人感興趣:
{{ define "thread" }}<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>test thread page</title>
<link rel="stylesheet" type="text/css" href="/static/board.css" />
<script type="text/javascript" src="/static/general.js"></script>
</head>
<body>
<h1>hello, world.</h1>
</body>
</html>
{{ end }}
如果“單個請求”是由瀏覽器發出的,則實際上可能是多個請求。 例如。 一些瀏覽器可能會要求提供網站圖標。 如果您想要一個有保證的單一請求,那么我建議為此目的編寫一個簡單的工具。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.