diff options
Diffstat (limited to 'src/mime')
| -rw-r--r-- | src/mime/multipart/example_test.go | 40 | ||||
| -rw-r--r-- | src/mime/multipart/formdata.go | 2 | ||||
| -rw-r--r-- | src/mime/multipart/multipart.go | 3 |
3 files changed, 43 insertions, 2 deletions
diff --git a/src/mime/multipart/example_test.go b/src/mime/multipart/example_test.go index fe154ac4f6..7a22ff789e 100644 --- a/src/mime/multipart/example_test.go +++ b/src/mime/multipart/example_test.go @@ -50,3 +50,43 @@ func ExampleNewReader() { // Part "one": "A section" // Part "two": "And another" } + +func ExampleReader_ReadForm() { + body := strings.NewReader( + "--foo\r\nContent-Disposition: form-data; name=\"field1\"\r\n\r\n" + + "Value of field.\r\n" + + "--foo\r\nContent-Disposition: form-data; name=\"file1\"; filename=\"file1.txt\"\r\n\r\n" + + "Value of file1.\r\n" + + "--foo--\r\n") + + mr := multipart.NewReader(body, "foo") + form, err := mr.ReadForm(0) + if err != nil { + log.Fatal(err) + } + + for name, val := range form.Value { + fmt.Printf("Form.Value %q: %q\n", name, val) + } + for name, listHeader := range form.File { + for _, hdr := range listHeader { + file, err := hdr.Open() + if err != nil { + log.Fatal(err) + } + content, err := io.ReadAll(file) + if err != nil { + log.Fatal(err) + } + fmt.Printf("Form.File %q:\n", name) + fmt.Printf(" Filename: %q\n", hdr.Filename) + fmt.Printf(" Content: %q\n", content) + } + } + + // Output: + // Form.Value "field1": ["Value of field."] + // Form.File "file1": + // Filename: "file1.txt" + // Content: "Value of file1." +} diff --git a/src/mime/multipart/formdata.go b/src/mime/multipart/formdata.go index f8258a961c..f2ca0118a6 100644 --- a/src/mime/multipart/formdata.go +++ b/src/mime/multipart/formdata.go @@ -108,7 +108,7 @@ func (r *Reader) readForm(maxMemory int64) (_ *Form, err error) { var copyBuf []byte for { p, err := r.nextPart(false, maxMemoryBytes, maxHeaders) - if err == io.EOF { + if errors.Is(err, io.EOF) { break } if err != nil { diff --git a/src/mime/multipart/multipart.go b/src/mime/multipart/multipart.go index da1f45810e..c570f1d7e2 100644 --- a/src/mime/multipart/multipart.go +++ b/src/mime/multipart/multipart.go @@ -30,6 +30,7 @@ package multipart import ( "bufio" "bytes" + "errors" "fmt" "internal/godebug" "io" @@ -392,7 +393,7 @@ func (r *Reader) nextPart(rawPart bool, maxMIMEHeaderSize, maxMIMEHeaders int64) for { line, err := r.bufReader.ReadSlice('\n') - if err == io.EOF && r.isFinalBoundary(line) { + if errors.Is(err, io.EOF) && r.isFinalBoundary(line) { // If the buffer ends in "--boundary--" without the // trailing "\r\n", ReadSlice will return an error // (since it's missing the '\n'), but this is a valid |
