aboutsummaryrefslogtreecommitdiff
path: root/src/mime
diff options
context:
space:
mode:
authorIllirgway <illirgway@gmail.com>2021-07-05 11:22:03 +0000
committerIan Lance Taylor <iant@golang.org>2021-11-09 22:58:24 +0000
commit578ada410de8065dbca46bca08a5993d1307f423 (patch)
tree577ce05e6984458ec217be653c89c5ea19da851e /src/mime
parent795cb333d94ee7f5632500f3e2ae98012b8d73e6 (diff)
downloadgo-578ada410de8065dbca46bca08a5993d1307f423.tar.gz
go-578ada410de8065dbca46bca08a5993d1307f423.zip
mime: keep parsing after trailing semicolon
Fixes #46323 Change-Id: Ibd624b1aaa15f907b7eb965b4eaec61018a45486 GitHub-Last-Rev: 7ad670b088144a2a09860dd990c53dea75c0d40f GitHub-Pull-Request: golang/go#47029 Reviewed-on: https://go-review.googlesource.com/c/go/+/332509 Trust: Ian Lance Taylor <iant@golang.org> Trust: Damien Neil <dneil@google.com> Reviewed-by: Damien Neil <dneil@google.com>
Diffstat (limited to 'src/mime')
-rw-r--r--src/mime/mediatype.go2
-rw-r--r--src/mime/mediatype_test.go17
2 files changed, 15 insertions, 4 deletions
diff --git a/src/mime/mediatype.go b/src/mime/mediatype.go
index 9456570cf1..6c1b095065 100644
--- a/src/mime/mediatype.go
+++ b/src/mime/mediatype.go
@@ -163,7 +163,7 @@ func ParseMediaType(v string) (mediatype string, params map[string]string, err e
if strings.TrimSpace(rest) == ";" {
// Ignore trailing semicolons.
// Not an error.
- return
+ break
}
// Parse error.
return mediatype, nil, ErrInvalidMediaParameter
diff --git a/src/mime/mediatype_test.go b/src/mime/mediatype_test.go
index e91ff38d68..079c080db7 100644
--- a/src/mime/mediatype_test.go
+++ b/src/mime/mediatype_test.go
@@ -42,7 +42,7 @@ func TestConsumeValue(t *testing.T) {
{`"My \" value"end`, "My \" value", "end"},
{`"\" rest`, "", `"\" rest`},
{`"C:\dev\go\robots.txt"`, `C:\dev\go\robots.txt`, ""},
- {`"C:\新建文件件\中文第二次测试.mp4"`, `C:\新建文件件\中文第二次测试.mp4`, ""},
+ {`"C:\新建文件夹\中文第二次测试.mp4"`, `C:\新建文件夹\中文第二次测试.mp4`, ""},
}
for _, test := range tests {
value, rest := consumeValue(test[0])
@@ -394,10 +394,21 @@ func TestParseMediaType(t *testing.T) {
// Empty string used to be mishandled.
{`foo; bar=""`, "foo", m("bar", "")},
- // Microsoft browers in intranet mode do not think they need to escape \ in file name.
+ // Microsoft browsers in intranet mode do not think they need to escape \ in file name.
{`form-data; name="file"; filename="C:\dev\go\robots.txt"`, "form-data", m("name", "file", "filename", `C:\dev\go\robots.txt`)},
- {`form-data; name="file"; filename="C:\新建文件件\中文第二次测试.mp4"`, "form-data", m("name", "file", "filename", `C:\新建文件件\中文第二次测试.mp4`)},
+ {`form-data; name="file"; filename="C:\新建文件夹\中文第二次测试.mp4"`, "form-data", m("name", "file", "filename", `C:\新建文件夹\中文第二次测试.mp4`)},
+
+ // issue #46323 (https://github.com/golang/go/issues/46323)
+ {
+ // example from rfc2231-p.3 (https://datatracker.ietf.org/doc/html/rfc2231)
+ `message/external-body; access-type=URL;
+ URL*0="ftp://";
+ URL*1="cs.utk.edu/pub/moore/bulk-mailer/bulk-mailer.tar";`, // <-- trailing semicolon
+ `message/external-body`,
+ m("access-type", "URL", "url", "ftp://cs.utk.edu/pub/moore/bulk-mailer/bulk-mailer.tar"),
+ },
}
+
for _, test := range tests {
mt, params, err := ParseMediaType(test.in)
if err != nil {