Content-Type: multipart/form-data の API への投稿
Content-Type を必要とする API への POST を試みる場合: multipart/form-data では、[]byte パラメータと文字列引数を使用している場合に問題が発生する可能性があります。表示されたエラー メッセージはリダイレクトの問題を示していますが、これは当面の問題とは無関係です。
解決策は、マルチパート パッケージを使用してマルチパート/フォーム データ リクエスト本文を構築することにあります。以下に例を示します。
<code class="go">package main import ( "bytes" "fmt" "io" "io/ioutil" "mime/multipart" "net/http" "github.com/ganshane/typeregistry" ) type FileItem struct { Key string //image_content FileName string //test.jpg Content []byte //[]byte } func NewPostFile(url string, paramTexts map[string]interface{}, paramFile FileItem) ([]byte, error) { // Construct the multipart request body bodyBuf := &bytes.Buffer{} bodyWriter := multipart.NewWriter(bodyBuf) for k, v := range paramTexts { bodyWriter.WriteField(k, v.(string)) } fileWriter, err := bodyWriter.CreateFormFile(paramFile.Key, paramFile.FileName) if err != nil { fmt.Println(err) //fmt.Println("Create form file error: ", error) return nil, err } fileWriter.Write(paramFile.Content) contentType := bodyWriter.FormDataContentType() bodyWriter.Close() fmt.Println(bodyBuf.String()) // Perform the POST request resp, err := http.Post(url, contentType, bodyBuf) if err != nil { return nil, err } defer resp.Body.Close() fmt.Println(resp) // Handle the response if resp.StatusCode < 200 || resp.StatusCode >= 300 { b, _ := ioutil.ReadAll(resp.Body) return nil, fmt.Errorf("[%d %s]%s", resp.StatusCode, resp.Status, string(b)) } respData, err := ioutil.ReadAll(resp.Body) if err != nil { return nil, err } fmt.Println(string(respData)) return respData, nil } func main() { m := make(map[string]interface{}, 0) m["fileName"] = "good" m["name"] = typeregistry.Base64ToByte("/9j/4AAQSkZJRgABAQEAeAB4AAD/2wBDAAIBAQIBAQICAgICAgICAwUDAwMDAwYEBAMFBwYHBwcGBwcICQsJCAgKCAcHCg0KCgsMDAwMBwkODw0MDgsMDAz/2wBDAQICAgMDAwYDAwYMCAcIDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAz/wAARCAABAAEDASIAAhEBAxEB/8QAHwAAAQUBAQEBAQEAAAAAAAAAAAECAwQFBgcICQoL/8QAtRAAAgEDAwIEAwUFBAQAAAF9AQIDAAQRBRIhMUEGE1FhByJxFDKBkaEII0KxwRVS0fAkM2JyggkKFhcYGRolJicoKSo0NTY3ODk6Q0RFRkdISUpTVFVWV1hZWmNkZWZnaGlqc3R1dnd4eXqDhIWGh4iJipKTlJWWl5iZmqKjpKWmp6ipqrKztLW2t7i5usLDxMXGx8jJytLT1NXW19jZ2uHi4+Tl5ufo6erx8vP09fb3+Pn6/8QAHwEAAwEBAQEBAQEBAQAAAAAAAAECAwQFBgcICQoL/8QAtREAAgECBAQDBAcFBAQAAQJ3AAECAxEEBSExBhJBUQdhcRMiMoEIFEKRobHBCSMzUvAVYnLRChYkNOEl8RcYGRomJygpKjU2Nzg5OkNERUZHSElKU1RVVldYWVpjZGVmZ2hpanN0dXZ3eHl6goOEhYaHiImKkpOUlZaXmJmaoqOkpaanqKmqsrO0tba3uLm6wsPExcbHyMnK0tPU1dbX2Nna4uPk5ebn6Onq8vP09fb3+Pn6/9oADAMBAAIRAxEAPwDHooor+wD+Zz//2Q==") paramFile := FileItem{ Key: "image_content", FileName: "test.jpg", Content: m["name"].([]byte), } respData, err := NewPostFile("API_URL", m, paramFile) if err != nil { // Handle error } fmt.Println(string(respData)) } </code>
この例では、NewPostFile 関数を使用して、通常のフォーム フィールドとファイルの両方を含む multipart/form-data を含む POST リクエストを作成しました。この関数は、URL、文字列引数のマップ、およびファイル項目を入力として受け取ります。
API からの応答は、respData 変数から取得し、必要に応じて処理できます。エラー処理と応答処理のコードは、開発者が特定の要件に従って実装する必要があります。
この解決策は、Content-Type: multipart/form-data を使用した API への POST で発生していた問題に対処する必要があります。 []byte パラメータと文字列引数を使用します。
以上がContent-Type: multipart/form-data []byte パラメーターと文字列引数を使用して API に投稿する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。