This problem is the same as #1238, which was resolved by #1239. For that issue, the fix was to check in one place whether $this->mapCellXfIndex[$xfIndex] was set before using it. The sample spreadsheet supplied as a description for this problem had exactly the same problem in 2 other places in the code. In addition, there were 7 other places in the code where that particular item was used unchecked. This fix corrects all 9 locations. The spreadsheet supplied with the problem is used as the basis for some new tests, which particularly test column dimensions and styles, the problems involved in this case.
This commit is contained in:
parent
3844186397
commit
38fab4e632
@ -3622,7 +3622,9 @@ class Xls extends BaseReader
|
||||
$this->phpSheet->getColumnDimensionByColumn($i)->setVisible(!$isHidden);
|
||||
$this->phpSheet->getColumnDimensionByColumn($i)->setOutlineLevel($level);
|
||||
$this->phpSheet->getColumnDimensionByColumn($i)->setCollapsed($isCollapsed);
|
||||
$this->phpSheet->getColumnDimensionByColumn($i)->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
if (isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
$this->phpSheet->getColumnDimensionByColumn($i)->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -3731,7 +3733,7 @@ class Xls extends BaseReader
|
||||
$numValue = self::getIEEE754($rknum);
|
||||
|
||||
$cell = $this->phpSheet->getCell($columnString . ($row + 1));
|
||||
if (!$this->readDataOnly) {
|
||||
if (!$this->readDataOnly && isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
// add style information
|
||||
$cell->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
@ -3866,7 +3868,7 @@ class Xls extends BaseReader
|
||||
// offset: var; size: 4; RK value
|
||||
$numValue = self::getIEEE754(self::getInt4d($recordData, $offset + 2));
|
||||
$cell = $this->phpSheet->getCell($columnString . ($row + 1));
|
||||
if (!$this->readDataOnly) {
|
||||
if (!$this->readDataOnly && isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
// add style
|
||||
$cell->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
@ -3910,7 +3912,7 @@ class Xls extends BaseReader
|
||||
$numValue = self::extractNumber(substr($recordData, 6, 8));
|
||||
|
||||
$cell = $this->phpSheet->getCell($columnString . ($row + 1));
|
||||
if (!$this->readDataOnly) {
|
||||
if (!$this->readDataOnly && isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
// add cell style
|
||||
$cell->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
@ -4018,7 +4020,7 @@ class Xls extends BaseReader
|
||||
}
|
||||
|
||||
$cell = $this->phpSheet->getCell($columnString . ($row + 1));
|
||||
if (!$this->readDataOnly) {
|
||||
if (!$this->readDataOnly && isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
// add cell style
|
||||
$cell->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
@ -4156,7 +4158,7 @@ class Xls extends BaseReader
|
||||
break;
|
||||
}
|
||||
|
||||
if (!$this->readDataOnly) {
|
||||
if (!$this->readDataOnly && isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
// add cell style
|
||||
$cell->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
@ -4194,7 +4196,9 @@ class Xls extends BaseReader
|
||||
// Read cell?
|
||||
if (($this->getReadFilter() !== null) && $this->getReadFilter()->readCell($columnString, $row + 1, $this->phpSheet->getTitle())) {
|
||||
$xfIndex = self::getUInt2d($recordData, 4 + 2 * $i);
|
||||
$this->phpSheet->getCell($columnString . ($row + 1))->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
if (isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
$this->phpSheet->getCell($columnString . ($row + 1))->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -4245,7 +4249,7 @@ class Xls extends BaseReader
|
||||
$cell = $this->phpSheet->getCell($columnString . ($row + 1));
|
||||
$cell->setValueExplicit($value, DataType::TYPE_STRING);
|
||||
|
||||
if (!$this->readDataOnly) {
|
||||
if (!$this->readDataOnly && isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
// add cell style
|
||||
$cell->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
@ -4277,7 +4281,7 @@ class Xls extends BaseReader
|
||||
$xfIndex = self::getUInt2d($recordData, 4);
|
||||
|
||||
// add style information
|
||||
if (!$this->readDataOnly && $this->readEmptyCells) {
|
||||
if (!$this->readDataOnly && $this->readEmptyCells && isset($this->mapCellXfIndex[$xfIndex])) {
|
||||
$this->phpSheet->getCell($columnString . ($row + 1))->setXfIndex($this->mapCellXfIndex[$xfIndex]);
|
||||
}
|
||||
}
|
||||
|
@ -3,9 +3,9 @@
|
||||
namespace PhpOffice\PhpSpreadsheetTests\Reader;
|
||||
|
||||
use PhpOffice\PhpSpreadsheet\Reader\Xls;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use PhpOffice\PhpSpreadsheetTests\Functional\AbstractFunctional;
|
||||
|
||||
class XlsTest extends TestCase
|
||||
class XlsTest extends AbstractFunctional
|
||||
{
|
||||
/**
|
||||
* Test load Xls file.
|
||||
@ -17,4 +17,30 @@ class XlsTest extends TestCase
|
||||
$spreadsheet = $reader->load($filename);
|
||||
self::assertEquals('Title', $spreadsheet->getSheet(0)->getCell('A1')->getValue());
|
||||
}
|
||||
|
||||
/**
|
||||
* Test load Xls file with invalid xfIndex.
|
||||
*/
|
||||
public function testLoadXlsBug1505(): void
|
||||
{
|
||||
$filename = 'tests/data/Reader/XLS/bug1505.xls';
|
||||
$reader = new Xls();
|
||||
$spreadsheet = $reader->load($filename);
|
||||
$sheet = $spreadsheet->getActiveSheet();
|
||||
$col = $sheet->getHighestColumn();
|
||||
$row = $sheet->getHighestRow();
|
||||
|
||||
$newspreadsheet = $this->writeAndReload($spreadsheet, 'Xlsx');
|
||||
$newsheet = $newspreadsheet->getActiveSheet();
|
||||
$newcol = $newsheet->getHighestColumn();
|
||||
$newrow = $newsheet->getHighestRow();
|
||||
|
||||
self::assertEquals($spreadsheet->getSheetCount(), $newspreadsheet->getSheetCount());
|
||||
self::assertEquals($sheet->getTitle(), $newsheet->getTitle());
|
||||
self::assertEquals($sheet->getColumnDimensions(), $newsheet->getColumnDimensions());
|
||||
self::assertEquals($col, $newcol);
|
||||
self::assertEquals($row, $newrow);
|
||||
self::assertEquals($sheet->getCell('A1')->getFormattedValue(), $newsheet->getCell('A1')->getFormattedValue());
|
||||
self::assertEquals($sheet->getCell("$col$row")->getFormattedValue(), $newsheet->getCell("$col$row")->getFormattedValue());
|
||||
}
|
||||
}
|
||||
|
BIN
tests/data/Reader/XLS/bug1505.xls
Normal file
BIN
tests/data/Reader/XLS/bug1505.xls
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user