Title: Writing a small file into a ZipFile while forcing zip64 extensions results in an incorrect zip file · Issue #103861 · python/cpython · GitHub
Open Graph Title: Writing a small file into a ZipFile while forcing zip64 extensions results in an incorrect zip file · Issue #103861 · python/cpython
X Title: Writing a small file into a ZipFile while forcing zip64 extensions results in an incorrect zip file · Issue #103861 · python/cpython
Description: Bug report When forcing a small file to be added to a zipfile.Zipfile object with zip64 extensions when it doesn't need it, a Zip64 extra record is added to the resulting file, but the minimum version and filesize information are not upd...
Open Graph Description: Bug report When forcing a small file to be added to a zipfile.Zipfile object with zip64 extensions when it doesn't need it, a Zip64 extra record is added to the resulting file, but the minimum vers...
X Description: Bug report When forcing a small file to be added to a zipfile.Zipfile object with zip64 extensions when it doesn't need it, a Zip64 extra record is added to the resulting file, but the minimum ...
Opengraph URL: https://github.com/python/cpython/issues/103861
X: @github
Domain: github.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Writing a small file into a ZipFile while forcing zip64 extensions results in an incorrect zip file","articleBody":"# Bug report\r\n\r\nWhen forcing a small file to be added to a `zipfile.Zipfile` object with zip64 extensions when it doesn't need it, a Zip64 extra record is added to the resulting file, but the minimum version and filesize information are not updated to reflect this.\r\n\r\nAn example of this issue in the wild: https://github.com/pR0Ps/zipstream-ng/issues/13\r\n\r\n## To reproduce:\r\n\r\nCreate the file:\r\n```python\r\nimport zipfile\r\n\r\nwith zipfile.ZipFile(\"out.zip\", mode=\"w\", allowZip64=True) as zf:\r\n with zf.open(\"text.txt\", mode=\"w\", force_zip64=True) as zi:\r\n zi.write(b\"some data\")\r\n```\r\n\r\nUsing [zipdetails](https://github.com/pmqs/zipdetails) to parse information from the resulting file (red lines are incorrect):\r\n```patch\r\n 0000 LOCAL HEADER #1 04034B50\r\n-0004 Extract Zip Spec 14 '2.0'\r\n 0005 Extract OS 00 'MS-DOS'\r\n 0006 General Purpose Flag 0000\r\n 0008 Compression Method 0000 'Stored'\r\n 000A Last Mod Time 00210000 'Mon Dec 31 19:00:00 1979'\r\n 000E CRC D9C2E91E\r\n-0012 Compressed Length 00000009\r\n-0016 Uncompressed Length 00000009\r\n 001A Filename Length 0008\r\n 001C Extra Length 0014\r\n 001E Filename 'text.txt'\r\n 0026 Extra ID #0001 0001 'ZIP64'\r\n 0028 Length 0010\r\n 002A Uncompressed Size 0000000000000009\r\n 0032 Compressed Size 0000000000000009\r\n 003A PAYLOAD some data\r\n \r\n 0043 CENTRAL HEADER #1 02014B50\r\n-0047 Created Zip Spec 14 '2.0'\r\n 0048 Created OS 03 'Unix'\r\n-0049 Extract Zip Spec 14 '2.0'\r\n 004A Extract OS 00 'MS-DOS'\r\n 004B General Purpose Flag 0000\r\n 004D Compression Method 0000 'Stored'\r\n 004F Last Mod Time 00210000 'Mon Dec 31 19:00:00 1979'\r\n 0053 CRC D9C2E91E\r\n 0057 Compressed Length 00000009\r\n 005B Uncompressed Length 00000009\r\n 005F Filename Length 0008\r\n 0061 Extra Length 0000\r\n 0063 Comment Length 0000\r\n 0065 Disk Start 0000\r\n 0067 Int File Attributes 0000\r\n [Bit 0] 0 'Binary Data'\r\n 0069 Ext File Attributes 01800000\r\n 006D Local Header Offset 00000000\r\n 0071 Filename 'text.txt'\r\n \r\n 0079 END CENTRAL HEADER 06054B50\r\n 007D Number of this disk 0000\r\n 007F Central Dir Disk no 0000\r\n 0081 Entries in this disk 0001\r\n 0083 Total Entries 0001\r\n 0085 Size of Central Dir 00000036\r\n 0089 Offset to Central Dir 00000043\r\n 008D Comment Length 0000\r\n```\r\n\r\nIn this case, the Extract Zip Spec should be `0x2D` (`zipfile.ZIP64_VERSION`) and the Compressed/Uncompressed Lengths should both be `0xFFFFFFFF` in order to defer to the lengths in the Zip64 record.\r\n\r\n# Your environment\r\n\r\n- CPython versions tested on: 3.12.0\r\n- Operating system and architecture: macOS Mojave (x86)\r\n\r\n\u003c!-- gh-linked-prs --\u003e\r\n### Linked PRs\r\n* gh-103863\r\n* gh-104534\n\u003c!-- /gh-linked-prs --\u003e\r\n","author":{"url":"https://github.com/pR0Ps","@type":"Person","name":"pR0Ps"},"datePublished":"2023-04-25T23:58:03.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":0},"url":"https://github.com/103861/cpython/issues/103861"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:c195b558-802a-a904-b3bc-9d8aab7d61dd |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | D818:1D9BC3:61A10:84D3D:69695154 |
| html-safe-nonce | de79423759186949982f9b5c8c9d6d5c9ed3aa36bb022828c81e2662c37f4c87 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJEODE4OjFEOUJDMzo2MUExMDo4NEQzRDo2OTY5NTE1NCIsInZpc2l0b3JfaWQiOiI1NjEzMjM4MTM2OTYzOTQ0Nzg4IiwicmVnaW9uX2VkZ2UiOiJpYWQiLCJyZWdpb25fcmVuZGVyIjoiaWFkIn0= |
| visitor-hmac | 7c1303b64856abf22d15c24676d5f8e3505939c0a305e13be5e140e80f583230 |
| hovercard-subject-tag | issue:1684021582 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/python/cpython/103861/issue_layout |
| twitter:image | https://opengraph.githubassets.com/738dcee98c243e91bf5940f5860dc9fb59c232a4c77cba4a54fc2b8837f0e3d6/python/cpython/issues/103861 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/738dcee98c243e91bf5940f5860dc9fb59c232a4c77cba4a54fc2b8837f0e3d6/python/cpython/issues/103861 |
| og:image:alt | Bug report When forcing a small file to be added to a zipfile.Zipfile object with zip64 extensions when it doesn't need it, a Zip64 extra record is added to the resulting file, but the minimum vers... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | pR0Ps |
| hostname | github.com |
| expected-hostname | github.com |
| None | 54182691a21263b584d2e600b758e081b0ff1d10ffc0d2eefa51cf754b43b51d |
| turbo-cache-control | no-preview |
| go-import | github.com/python/cpython git https://github.com/python/cpython.git |
| octolytics-dimension-user_id | 1525981 |
| octolytics-dimension-user_login | python |
| octolytics-dimension-repository_id | 81598961 |
| octolytics-dimension-repository_nwo | python/cpython |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 81598961 |
| octolytics-dimension-repository_network_root_nwo | python/cpython |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | d69ac0477df0f87da03b8b06cebd187012d7a930 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width