簡體   English   中英

http.HandleFunc每個請求調用根處理程序3次

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM