Почему первый запрос к видео серверу не вернул байтовые данные видео - PullRequest
0 голосов
/ 10 марта 2020

Я написал простой видеосервер следующим образом:

package main

import (
    "log"
    "net/http"
    "os"
    "time"
)

func ServeHTTP(w http.ResponseWriter, r *http.Request) {
    video, err := os.Open("/Users/icheer/Downloads/jsc/jsc.mp4")
    if err != nil {
        log.Fatal(err)
    }
    defer video.Close()

    http.ServeContent(w, r, "jsc.mp4", time.Now(), video)
}

func main() {
    http.HandleFunc("/", ServeHTTP)
    _ = http.ListenAndServe(":8080", nil)
}

Он работает хорошо, но мне интересно, что chrome делает, когда я открываю http://localhost: 8080 в chrome.

enter image description here

Почему код состояния первого запроса 200, а 'Tim e' - Pending ' Что именно "Pending" точно означает? Как chrome узнал, что запрос показывает 'Pending'? И что меня больше всего смутило, так это то, что я не знаю, какая строка моего кода golang приводит к этому. Как показывает исходный код net/http/fs.go,

enter image description here

* sendSize - это общая длина видео 5357093240, поэтому я думаю, что первый запрос должен вернуть все байты данных видео, но на самом деле, размер ответа 177B, как показывает первое изображение, я не знаю, какая строка кода golang приводит к этому.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...