Skip to content

Commit dcccd63

Browse files
authored
Theme File Missing But Referenced in Spreadsheet (#3772)
* Theme File Missing But Referenced in Spreadsheet Fix #3770. A rels file points to a non-existent theme file in the spreadsheet. In other similar cases (e.g. PR #3771), Excel opens such a spreadsheet, but with an error pop-up. Not so with this file; it just opens the spreadsheet without the pop-up. PhpSpreadsheet will now account for this unusual situation as well. * Update CHANGELOG.md
1 parent 1282f3d commit dcccd63

File tree

4 files changed

+51
-0
lines changed

4 files changed

+51
-0
lines changed

CHANGELOG.md

+1
Original file line numberDiff line numberDiff line change
@@ -67,6 +67,7 @@ and this project adheres to [Semantic Versioning](https://semver.org).
6767
- Break Some Circular References. [PR #3716](https://github.com/PHPOffice/PhpSpreadsheet/pull/3716) [PR #3707](https://github.com/PHPOffice/PhpSpreadsheet/pull/3707)
6868
- Missing Font Index in Some Xls. [PR #3734](https://github.com/PHPOffice/PhpSpreadsheet/pull/3734)
6969
- Load Tables even with READ_DATA_ONLY. [PR #3726](https://github.com/PHPOffice/PhpSpreadsheet/pull/3726)
70+
- Theme File Missing but Referenced in Spreadsheet. [Issue #3770](https://github.com/PHPOffice/PhpSpreadsheet/issues/3770) [PR #3772](https://github.com/PHPOffice/PhpSpreadsheet/pull/3772)
7071

7172
## 1.29.0 - 2023-06-15
7273

src/PhpSpreadsheet/Reader/Xlsx.php

+3
Original file line numberDiff line numberDiff line change
@@ -427,6 +427,9 @@ protected function loadSpreadsheetFromFile(string $filename): Spreadsheet
427427
}
428428
switch ($rel['Type']) {
429429
case "$xmlNamespaceBase/theme":
430+
if (!$this->fileExistsInArchive($zip, "xl/{$relTarget}")) {
431+
break; // issue3770
432+
}
430433
$themeOrderArray = ['lt1', 'dk1', 'lt2', 'dk2'];
431434
$themeOrderAdditional = count($themeOrderArray);
432435

Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
1+
<?php
2+
3+
declare(strict_types=1);
4+
5+
namespace PhpOffice\PhpSpreadsheetTests\Reader\Xlsx;
6+
7+
use PhpOffice\PhpSpreadsheet\Reader\Xlsx;
8+
9+
class Issue3770Test extends \PHPUnit\Framework\TestCase
10+
{
11+
private static string $testbook = 'tests/data/Reader/XLSX/issue.3770.xlsx';
12+
13+
public function testPreliminaries(): void
14+
{
15+
$file = 'zip://';
16+
$file .= self::$testbook;
17+
$file .= '#xl/_rels/workbook.xml.rels';
18+
$data = file_get_contents($file);
19+
// rels file points to non-existent theme file
20+
if ($data === false) {
21+
self::fail('Unable to read file');
22+
} else {
23+
self::assertStringContainsString('Target="theme/theme1.xml"', $data);
24+
self::assertStringContainsString('Target="worksheets/sheet1.xml"', $data);
25+
}
26+
$file = 'zip://';
27+
$file .= self::$testbook;
28+
$file .= '#xl/theme/theme1.xml';
29+
$data = @file_get_contents($file);
30+
self::assertFalse($data);
31+
$file = 'zip://';
32+
$file .= self::$testbook;
33+
$file .= '#xl/worksheets/sheet1.xml';
34+
$data = file_get_contents($file);
35+
self::assertNotFalse($data);
36+
}
37+
38+
public function testLoadable(): void
39+
{
40+
$reader = new Xlsx();
41+
$spreadsheet = $reader->load(self::$testbook);
42+
$sheet = $spreadsheet->getActiveSheet();
43+
// Assert anything to confirm read succeeded
44+
self::assertSame('Универсальный передаточный документ', $sheet->getCell('A1')->getValue());
45+
$spreadsheet->disconnectWorksheets();
46+
}
47+
}
11.7 KB
Binary file not shown.

0 commit comments

Comments
 (0)