Skip to content

Commit 45052f8

Browse files
authored
Merge commit from fork
1 parent 700a803 commit 45052f8

File tree

7 files changed

+74
-4
lines changed

7 files changed

+74
-4
lines changed

Diff for: src/PhpSpreadsheet/Writer/Html.php

+5-4
Original file line numberDiff line numberDiff line change
@@ -403,12 +403,12 @@ public function generateHTMLHeader(bool $includeStyles = false): string
403403
} else {
404404
$propertyValue = (string) $propertyValue;
405405
}
406-
$html .= self::generateMeta($propertyValue, "custom.$propertyQualifier.$customProperty");
406+
$html .= self::generateMeta($propertyValue, htmlspecialchars("custom.$propertyQualifier.$customProperty"));
407407
}
408408
}
409409

410410
if (!empty($properties->getHyperlinkBase())) {
411-
$html .= ' <base href="' . $properties->getHyperlinkBase() . '" />' . PHP_EOL;
411+
$html .= ' <base href="' . htmlspecialchars($properties->getHyperlinkBase()) . '" />' . PHP_EOL;
412412
}
413413

414414
$html .= $includeStyles ? $this->generateStyles(true) : $this->generatePageDeclarations(true);
@@ -1586,8 +1586,9 @@ private function generateRow(Worksheet $worksheet, array $values, int $row, stri
15861586
// Hyperlink?
15871587
if ($worksheet->hyperlinkExists($coordinate) && !$worksheet->getHyperlink($coordinate)->isInternal()) {
15881588
$url = $worksheet->getHyperlink($coordinate)->getUrl();
1589-
$urldecode = strtolower(html_entity_decode(trim($url), encoding: 'UTF-8'));
1590-
$parseScheme = preg_match('/^(\\w+):/', $urldecode, $matches);
1589+
$urlDecode1 = html_entity_decode($url, ENT_QUOTES | ENT_SUBSTITUTE, 'UTF-8');
1590+
$urlTrim = preg_replace('/^\\s+/u', '', $urlDecode1) ?? $urlDecode1;
1591+
$parseScheme = preg_match('/^([\\w\\s]+):/u', strtolower($urlTrim), $matches);
15911592
if ($parseScheme === 1 && !in_array($matches[1], ['http', 'https', 'file', 'ftp', 's3'], true)) {
15921593
$cellData = htmlspecialchars($url, Settings::htmlEntityFlags());
15931594
} else {
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
<?php
2+
3+
declare(strict_types=1);
4+
5+
namespace PhpOffice\PhpSpreadsheetTests\Writer\Html;
6+
7+
use PhpOffice\PhpSpreadsheet\Reader\Xlsx as XlsxReader;
8+
use PhpOffice\PhpSpreadsheet\Writer\Html as HtmlWriter;
9+
use PHPUnit\Framework\TestCase;
10+
11+
class BadCustomPropertyTest extends TestCase
12+
{
13+
public function testBadCustomProperty(): void
14+
{
15+
$reader = new XlsxReader();
16+
$infile = 'tests/data/Reader/XLSX/sec-q229.dontuse';
17+
$spreadsheet = $reader->load($infile);
18+
$writer = new HtmlWriter($spreadsheet);
19+
$html = $writer->generateHtmlAll();
20+
self::assertStringContainsString('<meta name="custom.string.custom_property&quot;&gt;&lt;img src=1 onerror=alert()&gt;" content="test" />', $html);
21+
$spreadsheet->disconnectWorksheets();
22+
}
23+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
<?php
2+
3+
declare(strict_types=1);
4+
5+
namespace PhpOffice\PhpSpreadsheetTests\Writer\Html;
6+
7+
use PhpOffice\PhpSpreadsheet\Reader\Xlsx as XlsxReader;
8+
use PhpOffice\PhpSpreadsheet\Writer\Html as HtmlWriter;
9+
use PHPUnit\Framework\TestCase;
10+
11+
class BadHyperlinkBaseTest extends TestCase
12+
{
13+
public function testBadHyperlinkBase(): void
14+
{
15+
$reader = new XlsxReader();
16+
$infile = 'tests/data/Reader/XLSX/sec-p66w.dontuse';
17+
$spreadsheet = $reader->load($infile);
18+
$writer = new HtmlWriter($spreadsheet);
19+
$html = $writer->generateHtmlAll();
20+
self::assertStringContainsString('<base href="&quot;&gt;&lt;img src=1 onerror=alert()&gt;" />', $html);
21+
$spreadsheet->disconnectWorksheets();
22+
}
23+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
<?php
2+
3+
declare(strict_types=1);
4+
5+
namespace PhpOffice\PhpSpreadsheetTests\Writer\Html;
6+
7+
use PhpOffice\PhpSpreadsheet\Reader\Xlsx as XlsxReader;
8+
use PhpOffice\PhpSpreadsheet\Writer\Html as HtmlWriter;
9+
use PHPUnit\Framework\TestCase;
10+
11+
class BadHyperlinkTest extends TestCase
12+
{
13+
public function testBadHyperlink(): void
14+
{
15+
$reader = new XlsxReader();
16+
$infile = 'tests/data/Reader/XLSX/sec-j47r.dontuse';
17+
$spreadsheet = $reader->load($infile);
18+
$writer = new HtmlWriter($spreadsheet);
19+
$html = $writer->generateHtmlAll();
20+
self::assertStringContainsString("<td class=\"column0 style1 f\">jav\tascript:alert()</td>", $html);
21+
$spreadsheet->disconnectWorksheets();
22+
}
23+
}

Diff for: tests/data/Reader/XLSX/sec-j47r.dontuse

8.68 KB
Binary file not shown.

Diff for: tests/data/Reader/XLSX/sec-p66w.dontuse

8.11 KB
Binary file not shown.

Diff for: tests/data/Reader/XLSX/sec-q229.dontuse

8.73 KB
Binary file not shown.

0 commit comments

Comments
 (0)