!c99Shell v. 1.0 pre-release build #16!

Software: Apache/2.2.3 (CentOS). PHP/5.1.6 

uname -a: Linux mx-ll-110-164-51-230.static.3bb.co.th 2.6.18-194.el5PAE #1 SMP Fri Apr 2 15:37:44
EDT 2010 i686
 

uid=48(apache) gid=48(apache) groups=48(apache) 

Safe-mode: OFF (not secure)

/var/www/html/phpMyAdmin/libraries/PHPExcel/PHPExcel/Reader/   drwxr-xr-x
Free 51.91 GB of 127.8 GB (40.62%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     CSV.php (8.99 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * PHPExcel
 *
 * Copyright (c) 2006 - 2011 PHPExcel
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 *
 * @category   PHPExcel
 * @package    PHPExcel_Reader
 * @copyright  Copyright (c) 2006 - 2011 PHPExcel (http://www.codeplex.com/PHPExcel)
 * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt    LGPL
 * @version    1.7.6, 2011-02-27
 */


/** PHPExcel root directory */
if (!defined('PHPEXCEL_ROOT')) {
    
/**
     * @ignore
     */
    
define('PHPEXCEL_ROOT'dirname(__FILE__) . '/../../');
    require(
PHPEXCEL_ROOT 'PHPExcel/Autoloader.php');
}

/**
 * PHPExcel_Reader_CSV
 *
 * @category   PHPExcel
 * @package    PHPExcel_Reader
 * @copyright  Copyright (c) 2006 - 2011 PHPExcel (http://www.codeplex.com/PHPExcel)
 */
class PHPExcel_Reader_CSV implements PHPExcel_Reader_IReader
{
    
/**
     *    Input encoding
     *
     *    @access    private
     *    @var    string
     */
    
private $_inputEncoding    'UTF-8';

    
/**
     *    Delimiter
     *
     *    @access    private
     *    @var string
     */
    
private $_delimiter        ',';

    
/**
     *    Enclosure
     *
     *    @access    private
     *    @var    string
     */
    
private $_enclosure        '"';

    
/**
     *    Line ending
     *
     *    @access    private
     *    @var    string
     */
    
private $_lineEnding    PHP_EOL;

    
/**
     *    Sheet index to read
     *
     *    @access    private
     *    @var    int
     */
    
private $_sheetIndex    0;

    
/**
     *    Load rows contiguously
     *
     *    @access    private
     *    @var    int
     */
    
private $_contiguous    false;


    
/**
     *    Row counter for loading rows contiguously
     *
     *    @access    private
     *    @var    int
     */
    
private $_contiguousRow    = -1;

    
/**
     *    PHPExcel_Reader_IReadFilter instance
     *
     *    @access    private
     *    @var    PHPExcel_Reader_IReadFilter
     */
    
private $_readFilter null;

    
/**
     *    Create a new PHPExcel_Reader_CSV
     */
    
public function __construct() {
        
$this->_readFilter        = new PHPExcel_Reader_DefaultReadFilter();
    }    
//    function __construct()

    /**
     *    Can the current PHPExcel_Reader_IReader read the file?
     *
     *    @access    public
     *    @param     string         $pFileName
     *    @return boolean
     *    @throws Exception
     */
    
public function canRead($pFilename)
    {
        
// Check if file exists
        
if (!file_exists($pFilename)) {
            throw new 
Exception("Could not open " $pFilename " for reading! File does not exist.");
        }

        return 
true;
    }    
//    function canRead()

    /**
     *    Loads PHPExcel from file
     *
     *    @access    public
     *    @param     string         $pFilename
     *    @return PHPExcel
     *    @throws Exception
     */
    
public function load($pFilename)
    {
        
// Create new PHPExcel
        
$objPHPExcel = new PHPExcel();

        
// Load into this instance
        
return $this->loadIntoExisting($pFilename$objPHPExcel);
    }    
//    function load()

    /**
     *    Read filter
     *
     *    @access    public
     *    @return PHPExcel_Reader_IReadFilter
     */
    
public function getReadFilter() {
        return 
$this->_readFilter;
    }    
//    function getReadFilter()

    /**
     *    Set read filter
     *
     *    @access    public
     *    @param    PHPExcel_Reader_IReadFilter $pValue
     */
    
public function setReadFilter(PHPExcel_Reader_IReadFilter $pValue) {
        
$this->_readFilter $pValue;
        return 
$this;
    }    
//    function setReadFilter()

    /**
     *    Set input encoding
     *
     *    @access    public
     *    @param string $pValue Input encoding
     */
    
public function setInputEncoding($pValue 'UTF-8')
    {
        
$this->_inputEncoding $pValue;
        return 
$this;
    }    
//    function setInputEncoding()

    /**
     *    Get input encoding
     *
     *    @access    public
     *    @return string
     */
    
public function getInputEncoding()
    {
        return 
$this->_inputEncoding;
    }    
//    function getInputEncoding()

    /**
     *    Loads PHPExcel from file into PHPExcel instance
     *
     *    @access    public
     *    @param     string         $pFilename
     *    @param    PHPExcel    $objPHPExcel
     *    @return     PHPExcel
     *    @throws     Exception
     */
    
public function loadIntoExisting($pFilenamePHPExcel $objPHPExcel)
    {
        
// Check if file exists
        
if (!file_exists($pFilename)) {
            throw new 
Exception("Could not open " $pFilename " for reading! File does not exist.");
        }

        
// Create new PHPExcel
        
while ($objPHPExcel->getSheetCount() <= $this->_sheetIndex) {
            
$objPHPExcel->createSheet();
        }
        
$objPHPExcel->setActiveSheetIndex$this->_sheetIndex );

        
// Open file
        
$fileHandle fopen($pFilename'r');
        if (
$fileHandle === false) {
            throw new 
Exception("Could not open file $pFilename for reading.");
        }

        
// Skip BOM, if any
        
switch ($this->_inputEncoding) {
            case 
'UTF-8':
                
fgets($fileHandle4) == "\xEF\xBB\xBF" ?
                    
fseek($fileHandle3) : fseek($fileHandle0);
                break;
            case 
'UTF-16LE':
                
fgets($fileHandle3) == "\xFF\xFE" ?
                    
fseek($fileHandle2) : fseek($fileHandle0);
                break;
            case 
'UTF-16BE':
                
fgets($fileHandle3) == "\xFE\xFF" ?
                    
fseek($fileHandle2) : fseek($fileHandle0);
                break;
            case 
'UTF-32LE':
                
fgets($fileHandle5) == "\xFF\xFE\x00\x00" ?
                    
fseek($fileHandle4) : fseek($fileHandle0);
                break;
            case 
'UTF-32BE':
                
fgets($fileHandle5) == "\x00\x00\xFE\xFF" ?
                    
fseek($fileHandle4) : fseek($fileHandle0);
                break;
            default:
                break;
        }

        
$escapeEnclosures = array( "\\" $this->_enclosure,
                                   
$this->_enclosure $this->_enclosure
                                 
);

        
// Set our starting row based on whether we're in contiguous mode or not
        
$currentRow 1;
        if (
$this->_contiguous) {
            
$currentRow = ($this->_contiguousRow == -1) ? $objPHPExcel->getActiveSheet()->getHighestRow(): $this->_contiguousRow;
        }

        
// Loop through each line of the file in turn
        
while (($rowData fgetcsv($fileHandle0$this->_delimiter$this->_enclosure)) !== FALSE) {
            
$columnLetter 'A';
            foreach(
$rowData as $rowDatum) {
                if (
$rowDatum != '' && $this->_readFilter->readCell($columnLetter$currentRow)) {
                    
// Unescape enclosures
                    
$rowDatum str_replace($escapeEnclosures$this->_enclosure$rowDatum);

                    
// Convert encoding if necessary
                    
if ($this->_inputEncoding !== 'UTF-8') {
                        
$rowDatum PHPExcel_Shared_String::ConvertEncoding($rowDatum'UTF-8'$this->_inputEncoding);
                    }

                    
// Set cell value
                    
$objPHPExcel->getActiveSheet()->getCell($columnLetter $currentRow)->setValue($rowDatum);
                }
                ++
$columnLetter;
            }
            ++
$currentRow;
        }

        
// Close file
        
fclose($fileHandle);

        if (
$this->_contiguous) {
            
$this->_contiguousRow $currentRow;
        }

        
// Return
        
return $objPHPExcel;
    }    
//    function loadIntoExisting()

    /**
     *    Get delimiter
     *
     *    @access    public
     *    @return string
     */
    
public function getDelimiter() {
        return 
$this->_delimiter;
    }    
//    function getDelimiter()

    /**
     *    Set delimiter
     *
     *    @access    public
     *    @param    string    $pValue        Delimiter, defaults to ,
     *    @return    PHPExcel_Reader_CSV
     */
    
public function setDelimiter($pValue ',') {
        
$this->_delimiter $pValue;
        return 
$this;
    }    
//    function setDelimiter()

    /**
     *    Get enclosure
     *
     *    @access    public
     *    @return string
     */
    
public function getEnclosure() {
        return 
$this->_enclosure;
    }    
//    function getEnclosure()

    /**
     *    Set enclosure
     *
     *    @access    public
     *    @param    string    $pValue        Enclosure, defaults to "
     *    @return PHPExcel_Reader_CSV
     */
    
public function setEnclosure($pValue '"') {
        if (
$pValue == '') {
            
$pValue '"';
        }
        
$this->_enclosure $pValue;
        return 
$this;
    }    
//    function setEnclosure()

    /**
     *    Get line ending
     *
     *    @access    public
     *    @return string
     */
    
public function getLineEnding() {
        return 
$this->_lineEnding;
    }    
//    function getLineEnding()

    /**
     *    Set line ending
     *
     *    @access    public
     *    @param    string    $pValue        Line ending, defaults to OS line ending (PHP_EOL)
     *    @return PHPExcel_Reader_CSV
     */
    
public function setLineEnding($pValue PHP_EOL) {
        
$this->_lineEnding $pValue;
        return 
$this;
    }    
//    function setLineEnding()

    /**
     *    Get sheet index
     *
     *    @access    public
     *    @return int
     */
    
public function getSheetIndex() {
        return 
$this->_sheetIndex;
    }    
//    function getSheetIndex()

    /**
     *    Set sheet index
     *
     *    @access    public
     *    @param    int        $pValue        Sheet index
     *    @return PHPExcel_Reader_CSV
     */
    
public function setSheetIndex($pValue 0) {
        
$this->_sheetIndex $pValue;
        return 
$this;
    }    
//    function setSheetIndex()

    /**
     *    Set Contiguous
     *
     *    @access    public
     *    @param string $pValue Input encoding
     */
    
public function setContiguous($contiguous false)
    {
        
$this->_contiguous = (bool)$contiguous;
        if (!
$contiguous) {
            
$this->_contiguousRow    = -1;
        }

        return 
$this;
    }    
//    function setInputEncoding()

    /**
     *    Get Contiguous
     *
     *    @access    public
     *    @return boolean
     */
    
public function getContiguous() {
        return 
$this->_contiguous;
    }    
//    function getSheetIndex()

}

:: Command execute ::

Enter:
 
Select:
 

:: Shadow's tricks :D ::

Useful Commands
 
Warning. Kernel may be alerted using higher levels
Kernel Info:

:: Preddy's tricks :D ::

Php Safe-Mode Bypass (Read Files)

File:

eg: /etc/passwd

Php Safe-Mode Bypass (List Directories):

Dir:

eg: /etc/

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

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

--[ c999shell v. 1.0 pre-release build #16 Modded by Shadow & Preddy | RootShell Security Group | r57 c99 shell | Generation time: 0.0078 ]--