"Content-Type: multipart/form-data"로 게시
"Content-Type: multipart/form-data"를 사용하는 경우 "[301 301 Moved Permanently]"와 같은 오류 메시지가 나타날 수 있습니다. 이 문제는 일반적으로 API에 대한 POST 바이트 매개변수 및 문자열 인수를 시도할 때 발생합니다.
이 오류를 해결하고 multipart/form-data를 사용하여 POST 요청을 성공적으로 수행하려면 Go 코드를 다음과 같이 수정하면 됩니다.
<code class="go">func NewPostFile(url string, paramTexts map[string]interface{}, paramFile FileItem) ([]byte, error) { // Create a multipart body buffer and writer bodyBuf := &bytes.Buffer{} bodyWriter := multipart.NewWriter(bodyBuf) // Add string parameters for k, v := range paramTexts { bodyWriter.WriteField(k, v.(string)) } // Add file parameter fileWriter, err := bodyWriter.CreateFormFile(paramFile.Key, paramFile.FileName) if err != nil { return nil, err } fileWriter.Write(paramFile.Content) // Set content type contentType := bodyWriter.FormDataContentType() // Close the writer bodyWriter.Close() resp, err := http.Post(url, contentType, bodyBuf) if err != nil { return nil, err } defer resp.Body.Close() // Handle response status 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)) } // Read response data respData, err := ioutil.ReadAll(resp.Body) if err != nil { return nil, err } return respData, nil } // Define FileItem type to represent file parameters type FileItem struct { Key string // e.g. "image_content" FileName string // e.g. "test.jpg" Content []byte // Byte array of the file }</code>
이 업데이트된 코드는 멀티파트 작성기와 함께 멀티파트/양식 데이터 콘텐츠 유형을 사용하여 POST 요청을 올바르게 구성합니다. 성공적인 요청을 수행하려면 API URL, 매개변수 텍스트 맵 및 파일 항목을 NewPostFile 함수에 제공할 수 있습니다.
위 내용은 Go에서 \'Content-Type: multipart/form-data\'로 게시할 때 \'[301 301 영구적으로 이동됨]\' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!