我正在嘗試使用goquery解析時間表內容,以便稍后使用它。但我有一個問題。我有兩個功能。第一個獲取html文檔并搜索令牌(csrfmiddlewaretoken),第二個使用此令牌發送請求并提取信息。完成從頁面中提取所有必要的信息后,我搜索令牌以在將來的請求中使用它并存儲它。但是由于某種原因,發現的令牌在到達時會變成空字符串。如果我在語句之前打印令牌的長度,它會打印以下內容:if len(foundCsrfToken) == 0 {...640...我已經擺脫了所有的戈魯丁,以防萬一這是問題。func findCsrfMiddlewareToken(responseBody io.Reader) (string, error) { document, err := goquery.NewDocumentFromReader(responseBody) if err != nil { return "", err } var foundCsrfToken string document.Find("script").Each(func(_ int, scrpt *goquery.Selection) { scriptText := scrpt.Text() if funcDefIndex := strings.Index(scriptText, "function Filter"); funcDefIndex != -1 { csrfTokenValueStart := strings.Index(scriptText, "csrfmiddlewaretoken: '") offset := csrfTokenValueStart + len("csrfmiddlewaretoken: '") foundCsrfToken = scriptText[offset : offset+csrfMiddlewareTokenLength] } }) if len(foundCsrfToken) == 0 { return "", errNoCsrfMiddlewareToken } return foundCsrfToken, nil}func (parser *TimetableParser) ParseTimetable(timetableFilterInfo internal.TimetableInfo) (internal.Timetable, error) { timetable := internal.Timetable{} requestBody := makeFormValues(timetableFilterInfo, parser.csrfMiddlewareToken).Encode() request, err := http.NewRequest("POST", baseUrl, strings.NewReader(requestBody)) if err != nil { return timetable, err } request.Header.Add("Content-Type", "application/x-www-form-urlencoded") request.Header.Add("Content-Length", strconv.Itoa(len(requestBody))) request.Header.Add("Referer", baseUrl) response, err := parser.client.Do(request) if err != nil { return timetable, err } defer response.Body.Close() document, err := goquery.NewDocumentFromReader(response.Body) if err != nil { return timetable, err }
1 回答

開心每一天1111
TA貢獻1836條經驗 獲得超13個贊
我剛剛意識到出了什么問題。哎呀。讀取器被視為流。因此,當我從中讀取一次時,它變得空了。如您所見,在收集了所有必要的信息并讀取響應之后,它被傳遞到第一個函數中。但它已經是空的了。當我第一次調用函數時,它像往常一樣工作并打印令牌長度(64)。但是當我以空響應進入第二個調用時,它打印0。findCsrfMiddlewareToken
- 1 回答
- 0 關注
- 132 瀏覽
添加回答
舉報
0/150
提交
取消