Dalam aplikasi web, adalah perkara biasa untuk menerima kedua-dua fail dan data JSON dalam permintaan HTTP. Untuk berjaya memproses elemen ini, adalah penting untuk memahami cara menghuraikannya dengan berkesan.
Pertimbangkan senario di mana anda mempunyai bahagian hadapan AngularJS yang menghantar permintaan ke bahagian belakang Go. Permintaan mengandungi fail ("fail") dan data JSON ("dokumen"). Matlamat anda adalah untuk menghuraikan kedua-dua fail PDF dan data JSON daripada permintaan ini.
Untuk menyelesaikan isu ini, anda perlu memproses kedua-dua fail dan data JSON secara berasingan. Dengan menggunakan http.(*Request).MultipartReader() dan mengulangi bahagian menggunakan NextPart(), anda boleh mengekstrak dan menghuraikan setiap elemen.
<code class="go">mr, err := r.MultipartReader() if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return }</code>
Untuk setiap bahagian dalam permintaan berbilang bahagian:
<code class="go">part, err := mr.NextPart() if err == io.EOF { break } if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return }</code>
Jika bahagian itu ialah fail ( part.FormName() == "file"):
<code class="go">outfile, err := os.Create("./docs/" + part.FileName()) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } defer outfile.Close() _, err = io.Copy(outfile, part) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return }</code>
Jika bahagian tersebut mengandungi data JSON (part.FormName() == "doc" ):
<code class="go">jsonDecoder := json.NewDecoder(part) err = jsonDecoder.Decode(&doc) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return }</code>
Selepas menghuraikan kedua-dua fail dan data JSON, anda boleh melakukan sebarang pasca pemprosesan yang diperlukan, seperti menyimpannya ke pangkalan data atau menghantar respons kepada pelanggan.
Atas ialah kandungan terperinci Bagaimana untuk Menghuraikan Fail dan Data JSON daripada Permintaan HTTP di Golang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!