!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/phpseclib/phpseclib/phpseclib/Crypt/Common/Formats/Keys/   drwxr-xr-x
Free 13.32 GB of 57.97 GB (22.97%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


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

/**
 * PKCS1 Formatted Key Handler
 *
 * PHP version 5
 *
 * @category  Crypt
 * @package   Common
 * @author    Jim Wigginton <terrafrost@php.net>
 * @copyright 2015 Jim Wigginton
 * @license   http://www.opensource.org/licenses/mit-license.html  MIT License
 * @link      http://phpseclib.sourceforge.net
 */

namespace phpseclib3\Crypt\Common\Formats\Keys;

use 
ParagonIE\ConstantTime\Base64;
use 
ParagonIE\ConstantTime\Hex;
use 
phpseclib3\Crypt\Random;
use 
phpseclib3\Crypt\AES;
use 
phpseclib3\Crypt\DES;
use 
phpseclib3\Crypt\TripleDES;
use 
phpseclib3\File\ASN1;
use 
phpseclib3\Common\Functions\Strings;
use 
phpseclib3\Exception\UnsupportedAlgorithmException;

/**
 * PKCS1 Formatted Key Handler
 *
 * @package RSA
 * @author  Jim Wigginton <terrafrost@php.net>
 * @access  public
 */
abstract class PKCS1 extends PKCS
{
    
/**
     * Default encryption algorithm
     *
     * @var string
     * @access private
     */
    
private static $defaultEncryptionAlgorithm 'AES-128-CBC';

    
/**
     * Sets the default encryption algorithm
     *
     * @access public
     * @param string $algo
     */
    
public static function setEncryptionAlgorithm($algo)
    {
        
self::$defaultEncryptionAlgorithm $algo;
    }

    
/**
     * Returns the mode constant corresponding to the mode string
     *
     * @access public
     * @param string $mode
     * @return int
     * @throws \UnexpectedValueException if the block cipher mode is unsupported
     */
    
private static function getEncryptionMode($mode)
    {
        switch (
$mode) {
            case 
'CBC':
            case 
'ECB':
            case 
'CFB':
            case 
'OFB':
            case 
'CTR':
                return 
$mode;
        }
        throw new 
\UnexpectedValueException('Unsupported block cipher mode of operation');
    }

    
/**
     * Returns a cipher object corresponding to a string
     *
     * @access public
     * @param string $algo
     * @return string
     * @throws \UnexpectedValueException if the encryption algorithm is unsupported
     */
    
private static function getEncryptionObject($algo)
    {
        
$modes '(CBC|ECB|CFB|OFB|CTR)';
        switch (
true) {
            case 
preg_match("#^AES-(128|192|256)-$modes$#"$algo$matches):
                
$cipher = new AES(self::getEncryptionMode($matches[2]));
                
$cipher->setKeyLength($matches[1]);
                return 
$cipher;
            case 
preg_match("#^DES-EDE3-$modes$#"$algo$matches):
                return new 
TripleDES(self::getEncryptionMode($matches[1]));
            case 
preg_match("#^DES-$modes$#"$algo$matches):
                return new 
DES(self::getEncryptionMode($matches[1]));
            default:
                throw new 
UnsupportedAlgorithmException($algo ' is not a supported algorithm');
        }
    }

    
/**
     * Generate a symmetric key for PKCS#1 keys
     *
     * @access private
     * @param string $password
     * @param string $iv
     * @param int $length
     * @return string
     */
    
private static function generateSymmetricKey($password$iv$length)
    {
        
$symkey '';
        
$iv substr($iv08);
        while (
strlen($symkey) < $length) {
            
$symkey.= md5($symkey $password $ivtrue);
        }
        return 
substr($symkey0$length);
    }

    
/**
     * Break a public or private key down into its constituent components
     *
     * @access public
     * @param string $key
     * @param string $password optional
     * @return array
     */
    
protected static function load($key$password)
    {
        if (!
Strings::is_stringable($key)) {
            throw new 
\UnexpectedValueException('Key should be a string - not a ' gettype($key));
        }

        
/* Although PKCS#1 proposes a format that public and private keys can use, encrypting them is
           "outside the scope" of PKCS#1.  PKCS#1 then refers you to PKCS#12 and PKCS#15 if you're wanting to
           protect private keys, however, that's not what OpenSSL* does.  OpenSSL protects private keys by adding
           two new "fields" to the key - DEK-Info and Proc-Type.  These fields are discussed here:

           http://tools.ietf.org/html/rfc1421#section-4.6.1.1
           http://tools.ietf.org/html/rfc1421#section-4.6.1.3

           DES-EDE3-CBC as an algorithm, however, is not discussed anywhere, near as I can tell.
           DES-CBC and DES-EDE are discussed in RFC1423, however, DES-EDE3-CBC isn't, nor is its key derivation
           function.  As is, the definitive authority on this encoding scheme isn't the IETF but rather OpenSSL's
           own implementation.  ie. the implementation *is* the standard and any bugs that may exist in that
           implementation are part of the standard, as well.

           * OpenSSL is the de facto standard.  It's utilized by OpenSSH and other projects */
        
if (preg_match('#DEK-Info: (.+),(.+)#'$key$matches)) {
            
$iv Hex::decode(trim($matches[2]));
            
// remove the Proc-Type / DEK-Info sections as they're no longer needed
            
$key preg_replace('#^(?:Proc-Type|DEK-Info): .*#m'''$key);
            
$ciphertext ASN1::extractBER($key);
            if (
$ciphertext === false) {
                
$ciphertext $key;
            }
            
$crypto self::getEncryptionObject($matches[1]);
            
$crypto->setKey(self::generateSymmetricKey($password$iv$crypto->getKeyLength() >> 3));
            
$crypto->setIV($iv);
            
$key $crypto->decrypt($ciphertext);
        } else {
            if (
self::$format != self::MODE_DER) {
                
$decoded ASN1::extractBER($key);
                if (
$decoded !== false) {
                    
$key $decoded;
                } elseif (
self::$format == self::MODE_PEM) {
                    throw new 
\UnexpectedValueException('Expected base64-encoded PEM format but was unable to decode base64 text');
                }
            }
        }

        return 
$key;
    }

    
/**
     * Wrap a private key appropriately
     *
     * @access public
     * @param string $key
     * @param string $type
     * @param string $password
     * @param array $options optional
     * @return string
     */
    
protected static function wrapPrivateKey($key$type$password, array $options = [])
    {
        if (empty(
$password) || !is_string($password)) {
            return 
"-----BEGIN $type PRIVATE KEY-----\r\n" .
                   
chunk_split(Base64::encode($key), 64) .
                   
"-----END $type PRIVATE KEY-----";
        }

        
$encryptionAlgorithm = isset($options['encryptionAlgorithm']) ? $options['encryptionAlgorithm'] : self::$defaultEncryptionAlgorithm;

        
$cipher self::getEncryptionObject($encryptionAlgorithm);
        
$iv Random::string($cipher->getBlockLength() >> 3);
        
$cipher->setKey(self::generateSymmetricKey($password$iv$cipher->getKeyLength() >> 3));
        
$cipher->setIV($iv);
        
$iv strtoupper(Hex::encode($iv));
        return 
"-----BEGIN $type PRIVATE KEY-----\r\n" .
               
"Proc-Type: 4,ENCRYPTED\r\n" .
               
"DEK-Info: " $encryptionAlgorithm",$iv\r\n" .
               
"\r\n" .
               
chunk_split(Base64::encode($cipher->encrypt($key)), 64) .
               
"-----END $type PRIVATE KEY-----";
    }

    
/**
     * Wrap a public key appropriately
     *
     * @access public
     * @param string $key
     * @param string $type
     * @return string
     */
    
protected static function wrapPublicKey($key$type)
    {
        return 
"-----BEGIN $type PUBLIC KEY-----\r\n" .
               
chunk_split(Base64::encode($key), 64) .
               
"-----END $type PUBLIC KEY-----";
    }
}

:: 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.0073 ]--