]> Cypherpunks repositories - gostls13.git/commit
[release-branch.go1.21] archive/zip: treat truncated EOCDR comment as an error
authorDamien Neil <dneil@google.com>
Tue, 14 May 2024 21:39:10 +0000 (14:39 -0700)
committerCarlos Amedee <carlos@golang.org>
Wed, 29 May 2024 23:37:27 +0000 (23:37 +0000)
commitc8e40338cf00f3c1d86c8fb23863ad67a4c72bcc
tree08c5691d26b9ff5fc7bbf380e367358bee09b94c
parent54c4745d7ca6650c4fe31be980277c85f97004ce
[release-branch.go1.21] archive/zip: treat truncated EOCDR comment as an error

When scanning for an end of central directory record,
treat an EOCDR signature with a record containing a truncated
comment as an error. Previously, we would skip over the invalid
record and look for another one. Other implementations do not
do this (they either consider this a hard error, or just ignore
the truncated comment). This parser misalignment allowed
presenting entirely different archive contents to Go programs
and other zip decoders.

For #66869
Fixes #67553

Change-Id: I94e5cb028534bb5704588b8af27f1e22ea49c7c6
Reviewed-on: https://go-review.googlesource.com/c/go/+/585397
Reviewed-by: Joseph Tsai <joetsai@digital-static.net>
Reviewed-by: Dmitri Shuralyov <dmitshur@google.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
(cherry picked from commit 33d725e5758bf1fea62e6c77fc70b57a828a49f5)
Reviewed-on: https://go-review.googlesource.com/c/go/+/588795
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
src/archive/zip/reader.go
src/archive/zip/reader_test.go
src/archive/zip/testdata/comment-truncated.zip [new file with mode: 0644]