!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/uploads/script/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Reader/Security/   drwxr-xr-x
Free 13.33 GB of 57.97 GB (23%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     XmlScanner.php (4.13 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace PhpOffice\PhpSpreadsheet\Reader\Security;

use 
PhpOffice\PhpSpreadsheet\Reader;
use 
PhpOffice\PhpSpreadsheet\Settings;

class 
XmlScanner
{
    
/**
     * String used to identify risky xml elements.
     *
     * @var string
     */
    
private $pattern;

    private 
$callback;

    private static 
$libxmlDisableEntityLoaderValue;

    public function 
__construct($pattern '<!DOCTYPE')
    {
        
$this->pattern $pattern;

        
$this->disableEntityLoaderCheck();

        
// A fatal error will bypass the destructor, so we register a shutdown here
        
register_shutdown_function([__CLASS__'shutdown']);
    }

    public static function 
getInstance(Reader\IReader $reader)
    {
        switch (
true) {
            case 
$reader instanceof Reader\Html:
                return new 
self('<!ENTITY');
            case 
$reader instanceof Reader\Xlsx:
            case 
$reader instanceof Reader\Xml:
            case 
$reader instanceof Reader\Ods:
            case 
$reader instanceof Reader\Gnumeric:
                return new 
self('<!DOCTYPE');
            default:
                return new 
self('<!DOCTYPE');
        }
    }

    public static function 
threadSafeLibxmlDisableEntityLoaderAvailability()
    {
        if (
PHP_MAJOR_VERSION == 7) {
            switch (
PHP_MINOR_VERSION) {
                case 
2:
                    return 
PHP_RELEASE_VERSION >= 1;
                case 
1:
                    return 
PHP_RELEASE_VERSION >= 13;
                case 
0:
                    return 
PHP_RELEASE_VERSION >= 27;
            }

            return 
true;
        }

        return 
false;
    }

    private function 
disableEntityLoaderCheck(): void
    
{
        if (
Settings::getLibXmlDisableEntityLoader() && \PHP_VERSION_ID 80000) {
            
$libxmlDisableEntityLoaderValue libxml_disable_entity_loader(true);

            if (
self::$libxmlDisableEntityLoaderValue === null) {
                
self::$libxmlDisableEntityLoaderValue $libxmlDisableEntityLoaderValue;
            }
        }
    }

    public static function 
shutdown(): void
    
{
        if (
self::$libxmlDisableEntityLoaderValue !== null && \PHP_VERSION_ID 80000) {
            
libxml_disable_entity_loader(self::$libxmlDisableEntityLoaderValue);
            
self::$libxmlDisableEntityLoaderValue null;
        }
    }

    public function 
__destruct()
    {
        
self::shutdown();
    }

    public function 
setAdditionalCallback(callable $callback): void
    
{
        
$this->callback $callback;
    }

    private function 
toUtf8($xml)
    {
        
$pattern '/encoding="(.*?)"/';
        
$result preg_match($pattern$xml$matches);
        
$charset strtoupper($result $matches[1] : 'UTF-8');

        if (
$charset !== 'UTF-8') {
            
$xml mb_convert_encoding($xml'UTF-8'$charset);

            
$result preg_match($pattern$xml$matches);
            
$charset strtoupper($result $matches[1] : 'UTF-8');
            if (
$charset !== 'UTF-8') {
                throw new 
Reader\Exception('Suspicious Double-encoded XML, spreadsheet file load() aborted to prevent XXE/XEE attacks');
            }
        }

        return 
$xml;
    }

    
/**
     * Scan the XML for use of <!ENTITY to prevent XXE/XEE attacks.
     *
     * @param mixed $xml
     *
     * @return string
     */
    
public function scan($xml)
    {
        
$this->disableEntityLoaderCheck();

        
$xml $this->toUtf8($xml);

        
// Don't rely purely on libxml_disable_entity_loader()
        
$pattern '/\\0?' implode('\\0?'str_split($this->pattern)) . '\\0?/';

        if (
preg_match($pattern$xml)) {
            throw new 
Reader\Exception('Detected use of ENTITY in XML, spreadsheet file load() aborted to prevent XXE/XEE attacks');
        }

        if (
$this->callback !== null && is_callable($this->callback)) {
            
$xml call_user_func($this->callback$xml);
        }

        return 
$xml;
    }

    
/**
     * Scan theXML for use of <!ENTITY to prevent XXE/XEE attacks.
     *
     * @param string $filestream
     *
     * @return string
     */
    
public function scanFile($filestream)
    {
        return 
$this->scan(file_get_contents($filestream));
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0053 ]--