This issue tracker has been migrated to GitHub ,
and is currently read-only.
For more information,
see the GitHub FAQs in the Python's Developer Guide.
Created on 2015年02月26日 10:22 by martin.panter, last changed 2022年04月11日 14:58 by admin. This issue is now closed.
| Files | ||||
|---|---|---|---|---|
| File name | Uploaded | Description | Edit | |
| gzip-bomb.patch | martin.panter, 2015年02月26日 10:22 | review | ||
| Messages (3) | |||
|---|---|---|---|
| msg236659 - (view) | Author: Martin Panter (martin.panter) * (Python committer) | Date: 2015年02月26日 10:22 | |
This is a patch I originally posted at Issue 15955, but am moving it to a separate issue so there is less confusion. GzipFile.read(<size>) etc is susceptible to decompression bombing. My patch tests and fixes that, making use of the existing "max_length" parameter in the "zlib" module. The rest of Issue 15955 is about enhancing the bzip and LZMA modules to support limited decompression, but since the zlib module can already limit the decompressed data, I think this gzip patch should be considered as a bug fix rather than enhancement, e.g. the fix for Issue 16043 (gzip decoding for XML RPC module) assumed GzipFile.read(<size>) is limited. |
|||
| msg236706 - (view) | Author: Nikolaus Rath (nikratio) * | Date: 2015年02月26日 21:10 | |
Especially now that this is only going to go into 3.5, I think it makes more sense to handle GzipFile, LZMAFile and BZ2File all in one go. Looking at the code, otherwise there's going to be a lot of duplication. How about introducing a base class 'CompressedFile' that defines most of the logic that's currently in LZMAFile (including the max_size patch from issue 23529), and having {LZMA,BZ2,Gzip}File all inherit from that base? BZ2File and LZMAFile would probably only need to define their own constructor to instantiate the proper compressor/decompressor object. GzipFile would need to additionally overwrite read() and write() in order to handle the CRC and gzip header. But I think both methods could still be written to call super().read/write(). Did I miss something? |
|||
| msg236861 - (view) | Author: Martin Panter (martin.panter) * (Python committer) | Date: 2015年02月28日 00:54 | |
Perhaps we should move the discussion of a common base class to Issue 23529. I only opened this as a separate issue because I thought it might be appropriate as a bug fix for 3.4. |
|||
| History | |||
|---|---|---|---|
| Date | User | Action | Args |
| 2022年04月11日 14:58:13 | admin | set | github: 67716 |
| 2015年04月10日 22:31:32 | pitrou | set | status: open -> closed superseder: Limit decompressed data when reading from LZMAFile and BZ2File resolution: duplicate stage: patch review -> resolved |
| 2015年02月28日 09:42:45 | Arfrever | set | nosy:
+ Arfrever |
| 2015年02月28日 00:54:29 | martin.panter | set | messages: + msg236861 |
| 2015年02月26日 21:10:02 | nikratio | set | messages: + msg236706 |
| 2015年02月26日 18:05:21 | pitrou | set | nosy:
+ pitrou |
| 2015年02月26日 12:12:20 | pitrou | set | stage: patch review versions: - Python 3.4 |
| 2015年02月26日 11:11:39 | serhiy.storchaka | set | nosy:
+ serhiy.storchaka |
| 2015年02月26日 10:23:24 | martin.panter | set | type: behavior -> resource usage |
| 2015年02月26日 10:22:06 | martin.panter | create | |