ホームページ  >  記事  >  バックエンド開発  >  Go で HTTP リクエスト内のマルチソース データを効果的に解析するにはどうすればよいですか?

Go で HTTP リクエスト内のマルチソース データを効果的に解析するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-10-25 01:59:02706ブラウズ

How to Effectively Parse Multi-Source Data in HTTP Requests with Go?

Go を使用した単一の HTTP リクエストからのファイルと JSON データの解析

単一の HTTP リクエスト内で複数のソースからのデータを解析するのは困難な場合があります。この場合、PDF ファイルと JSON データの両方を別個の部分として受信しています。このシナリオを効果的に処理するために、Go は multipart/form-data パッケージを提供します。

解決策:

この問題を解決する鍵は、r.MultipartReader() を使用することです。 。この関数は mime/multipart.Reader オブジェクトを返すため、リクエストの各部分を反復して個別に処理できるようになります。変更されたコードは次のとおりです。

<code class="go">func (s *Server) PostFileHandler(w http.ResponseWriter, r *http.Request) {
    mr, err := r.MultipartReader()
    if err != nil {
        http.Error(w, err.Error(), http.StatusInternalServerError)
        return
    }

    doc := Doc{}
    for {
        part, err := mr.NextPart()

        // End of parts
        if err == io.EOF {
            break
        }

        // Handle PDF 'file' part
        if part.FormName() == "file" {
            // ... PDF processing code
        }

        // Handle JSON 'doc' part
        if part.FormName() == "doc" {
            jsonDecoder := json.NewDecoder(part)
            err = jsonDecoder.Decode(&doc)
            if err != nil {
                http.Error(w, err.Error(), http.StatusInternalServerError)
                return
            }
            // ... JSON processing code
        }
    }

    // ... Database insertion and response handling code
}</code>

このアプローチを使用すると、PDF ファイルと JSON データを個別に解析し、リクエストの両方の部分が正しく処理されることを確認できます。

以上がGo で HTTP リクエスト内のマルチソース データを効果的に解析するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。