當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ssh2_auth_pubkey_file函數代碼示例

本文整理匯總了PHP中ssh2_auth_pubkey_file函數的典型用法代碼示例。如果您正苦於以下問題:PHP ssh2_auth_pubkey_file函數的具體用法?PHP ssh2_auth_pubkey_file怎麽用?PHP ssh2_auth_pubkey_file使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了ssh2_auth_pubkey_file函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: connect

 /**
  *
  */
 public function connect()
 {
     $this->ssh = ssh2_connect($this->configuration['hostname'], $this->configuration['port']);
     $username = $this->configuration['username'];
     switch ($this->configuration[SftpDriver::CONFIG_AUTHENTICATION_METHOD]) {
         case static::AUTHENTICATION_PASSWORD:
             ssh2_auth_password($this->ssh, $username, $this->configuration['password']);
             break;
         case static::AUTHENTICATION_PUBKEY:
             $publicKey = $this->configuration['publicKey'];
             $privateKey = $this->configuration['privateKey'];
             if (!file_exists($publicKey) || !file_exists($privateKey)) {
                 return;
             }
             $password = $this->configuration['privateKeyPassword'];
             if (empty($password)) {
                 $password = null;
             }
             ssh2_auth_pubkey_file($this->ssh, $username, $publicKey, $privateKey, $password);
             break;
         default:
     }
     $this->sftp = ssh2_sftp($this->ssh);
     $this->sftpWrapper = 'ssh2.sftp://' . $this->sftp;
     $this->sftpWrapperLength = strlen($this->sftpWrapper);
     $this->iteratorFlags = \FilesystemIterator::UNIX_PATHS | \FilesystemIterator::SKIP_DOTS | \FilesystemIterator::CURRENT_AS_FILEINFO | \FilesystemIterator::FOLLOW_SYMLINKS;
     return true;
 }
開發者ID:vertexvaar,項目名稱:falsftp,代碼行數:31,代碼來源:PhpSshAdapter.php

示例2: connect

 /**
  * Connect operation
  */
 public function connect()
 {
     if ($this->_ssh2 != null) {
         // Already connected
         return;
     }
     // Connect to server
     $host = isset($this->_config['hostname']) ? $this->_config['hostname'] : 'localhost';
     $port = isset($this->_config['port']) ? $this->_config['port'] : 22;
     $username = isset($this->_config['username']) ? $this->_config['username'] : '';
     $password = isset($this->_config['password']) ? $this->_config['password'] : null;
     $this->_ssh2 = ssh2_connect($host, $port);
     if ($this->_ssh2 === FALSE) {
         throw new Kohana_Transfer_Exception(Kohana::message('transfer', 'fail_open_connection'), array(':host' => $host, 'port' => $port));
     }
     // Check fingerprint if it is specified
     if (isset($this->_config['fingerprint'])) {
         if (strtolower(ssh2_fingerprint($this->_ssh2)) != strtolower($this->_config['fingerprint'])) {
             throw new Kohana_Transfer_Exception(Kohana::message('transfer', 'fail_fingerprint_validation'), array(':key' => ssh2_fingerprint($this->_ssh2)));
         }
     }
     // Connect with certificate if it is specified
     if (isset($this->_config['pubkeyfile']) and isset($this->_config['privkeyfile'])) {
         if (!@ssh2_auth_pubkey_file($this->_ssh2, $username, $this->_config['pubkeyfile'], $this->_config['privkeyfile'], $password)) {
             throw new Kohana_Transfer_Exception(Kohana::message('transfer', 'fail_authentication'));
         }
     } else {
         if (!@ssh2_auth_password($this->_ssh2, $username, $password)) {
             throw new Kohana_Transfer_Exception(Kohana::message('transfer', 'fail_authentication'));
         }
     }
     // Enable SFTP mode
     $this->_sftp = ssh2_sftp($this->_ssh2);
 }
開發者ID:rpringle,項目名稱:transfer,代碼行數:37,代碼來源:sftp.php

示例3: __construct

 public function __construct($config)
 {
     foreach ($config as $name => $value) {
         $this->{$name} = $value;
     }
     $methods = array();
     if (!isset($this->auth['method'])) {
         error('Unspecified authentication method.');
     }
     // Connect
     $this->connection = ssh2_connect($this->host, isset($this->port) ? $this->port : 22, $methods);
     switch ($this->auth['method']) {
         case 'pubkey':
             if (!isset($this->auth['public'])) {
                 error('Public key filename not specified.');
             }
             if (!isset($this->auth['private'])) {
                 error('Private key filename not specified.');
             }
             if (!ssh2_auth_pubkey_file($this->connection, $this->auth['username'], $this->auth['public'], $this->auth['private'], isset($this->auth['passphrase']) ? $this->auth['passphrase'] : null)) {
                 error('Public key authentication failed.');
             }
             break;
         case 'plain':
             if (!ssh2_auth_password($this->connection, $this->auth['username'], $this->auth['password'])) {
                 error('Plain-text authentication failed.');
             }
             break;
         default:
             error('Unknown authentication method: "' . $this->auth['method'] . '".');
     }
 }
開發者ID:0151n,項目名稱:vichan,代碼行數:32,代碼來源:remote.php

示例4: __construct

 function __construct($cfg)
 {
     // set default options if missing
     static $defaults = array('port' => 22, 'user' => 'root');
     if (is_object($cfg)) {
         $cfg = json_decode(json_encode($cfg), 1);
     }
     foreach ($defaults as $k => $v) {
         if (!isset($cfg[$k])) {
             $cfg[$k] = $v;
         }
     }
     // connect ssh2
     $this->ssh2 = ssh2_connect($cfg['host'], $cfg['port']);
     if (!$this->ssh2) {
         throw new \Exception("can't connect trough ssh2\n");
     }
     // authorize
     if (isset($cfg['key'])) {
         // private/public key authentication requested
         if (!ssh2_auth_pubkey_file($this->ssh2, $cfg['user'], $cfg['key']['pub'], $cfg['key']['pvt'], isset($cfg['key']['pass']) ? $cfg['key']['pass'] : NULL)) {
             throw new \Exception("can't authorize via key");
         }
     } elseif (isset($cfg['pass'])) {
         // username & password authentication
         if (!ssh2_auth_password($this->ssh2, $cfg['user'], $cfg['pass'])) {
             throw new \Exception("can't authorize via user & pass");
         }
     } else {
         throw new \Exception("not enough authentication information provided");
     }
     $this->sftp = ssh2_sftp($this->ssh2);
 }
開發者ID:ngorchilov,項目名稱:lgr,代碼行數:33,代碼來源:ssh2.class.php

示例5: connect

 public function connect()
 {
     $methods = array();
     if ($this->use_pubkey_file_) {
         $methods['hostkey'] = 'ssh-rsa';
     }
     $conn = ssh2_connect($this->conf_['host'], $this->conf_['port'], $methods);
     if (false === $conn) {
         $this->setErr_(-1, sprintf('failed to connect [%s:%d]', $this->conf_['host'], $this->conf_['port']));
         return false;
     }
     if ($this->use_pubkey_file_) {
         $rc = ssh2_auth_pubkey_file($conn, $this->conf_['user'], $this->conf_['pubkey_file'], $this->conf_['privkey_file'], isset($this->conf_['passphrase']) ? $this->conf_['passphrase'] : NULL);
         if (false === $rc) {
             $this->setErr_(-1, sprintf('failed to auth with[%s:%s,%s,%s]', $this->conf_['user'], $this->conf_['pubkey_file'], $this->conf_['privkey_file'], $this->conf_['passphrase']));
             return false;
         }
     } else {
         $rc = ssh2_auth_password($conn, $this->conf_['user'], $this->conf_['passwd']);
         if (false === $rc) {
             $this->setErr_(-1, sprintf('failed to auth with[%s:%s]', $this->conf_['user'], $this->conf_['passwd']));
             return false;
         }
     }
     $this->conn_ = $conn;
     return true;
 }
開發者ID:nicevoice,項目名稱:yhtx,代碼行數:27,代碼來源:Sftp.php

示例6: getOS

function getOS($pass = false)
{
    $ip = $_REQUEST['ip'];
    $sshp = $_REQUEST['sshp'];
    if (!isset($_REQUEST['sshp'])) {
        $sshp = '22';
    }
    $lsbresult1 = array();
    $methods = array('hostkey', 'ssh-rsa');
    if (isset($pass) && $pass) {
        $methods = array();
    }
    $connection = ssh2_connect($ip, $sshp, $methods);
    if (!$connection) {
        throw new Exception("fail: unable to establish connection, please Check IP or if server is on and connected");
    }
    $pass_success = false;
    if ($methods) {
        $rsa_pub = realpath($_SERVER['HOME'] . '/.ssh/id_rsa.pub');
        $rsa = realpath($_SERVER['HOME'] . '/.ssh/id_rsa');
        $pass_success = ssh2_auth_pubkey_file($connection, 'sysad', $rsa_pub, $rsa);
    } else {
        $pass_success = ssh2_auth_password($connection, 'root', $pass);
    }
    if (!$pass_success) {
        throw new Exception("fail: unable to establish connection\nPlease Check your password");
    }
    $cmd = "lsb_release -as";
    $stream = ssh2_exec($connection, $cmd);
    $errorStream = ssh2_fetch_stream($stream, SSH2_STREAM_STDERR);
    stream_set_blocking($errorStream, true);
    stream_set_blocking($stream, true);
    $lsbresult1 = stream_get_contents($stream);
    stream_set_blocking($errorStream, false);
    stream_set_blocking($stream, false);
    flush();
    fclose($errorStream);
    fclose($stream);
    fclose($rsa_pub);
    fclose($rsa);
    unset($connection);
    print_r($lsbresult1);
    $lsbresult = explode("\n", $lsbresult1);
    if (!empty($lsbresult)) {
        $OS = $lsbresult[0];
        $version = $lsbresult[3];
        $releasever = $lsbresult[2];
    } else {
        echo "No values present";
        die;
    }
    ssh2_exec($connection, 'exit');
    fclose($stream);
    fclose($errorStream);
    flush();
    unset($connection);
    fclose($connection);
    return array($OS, $version, $releasever);
}
開發者ID:shadowhome,項目名稱:synxb,代碼行數:59,代碼來源:functions.php

示例7: __construct

 public function __construct(FtpConfig $config)
 {
     $this->_config = $config;
     $this->_session = ssh2_connect($this->_config->getHost(), $this->_config->getPort());
     if (!ssh2_auth_pubkey_file($this->_session, $this->_config->getUser(), $this->_config->getPublicKey(), $this->_config->getPrivateKey())) {
         throw new \Exception("Could not connect to Ftp server with provided configuration");
     }
 }
開發者ID:native5,項目名稱:native5-sdk-common-php,代碼行數:8,代碼來源:FtpConnector.php

示例8: authPubkey

 public function authPubkey($user, $pubkeyFile, $privkeyFile, $passphrase)
 {
     if (!ssh2_auth_pubkey_file($this->connection, $user, $pubkeyFile, $privkeyFile, $passphrase)) {
         $this->logs[] = "Public Key Authorization failed";
         return false;
     }
     return true;
 }
開發者ID:nouphet,項目名稱:xoops-tpSocialMedia,代碼行數:8,代碼來源:Ssh2.php

示例9: connect

 public function connect()
 {
     $this->connection = ssh2_connect($this->settings['host'], $this->settings['port']);
     if (!$this->connection) {
         throw new \Exception("Could not connect to remote server.");
     }
     ssh2_auth_pubkey_file($this->connection, $this->settings['user'], $this->settings['publicKey'], $this->settings['privateKey']);
 }
開發者ID:radmiraal,項目名稱:PHP-Gerrit-Tools,代碼行數:8,代碼來源:SSH2.php

示例10: authenticate

 public function authenticate($user, $public_key, $private_key)
 {
     if (!$this->authenticated) {
         if (false === ($this->authenticated = ssh2_auth_pubkey_file($this->connection, $user, $public_key, $private_key))) {
             throw new SshException(sprintf('Authorization failed for user "%s"', $user));
         }
     }
 }
開發者ID:fiunchinho,項目名稱:plumber,代碼行數:8,代碼來源:SshConnection.php

示例11: ssh_connect

function ssh_connect($address)
{
    include 'config.php';
    $tmp = explode(":", $address);
    $ip = $tmp[0];
    $port = $tmp[1];
    global $connection;
    $connection = ssh2_connect($ip, $port, array('hostkey' => 'ssh-rsa'));
    ssh2_auth_pubkey_file($connection, $ssh_user, $ssh_key_path . 'id_rsa.pub', $ssh_key_path . 'id_rsa');
}
開發者ID:BillTheBest,項目名稱:kvm-vdi,代碼行數:10,代碼來源:functions.php

示例12: doLoginPubKey

 protected function doLoginPubKey($user, $pubKeyFile, $privKeyFile, $passphrase = null)
 {
     // try to login
     if (ssh2_auth_pubkey_file($this->getSsh2Connection(), $user, $pubKeyFile, $privKeyFile, $passphrase)) {
         $this->sftp_id = ssh2_sftp($this->getSsh2Connection());
         return $this->sftp_id != false && $this->sftp_id != null;
     } else {
         return false;
     }
 }
開發者ID:richhl,項目名稱:kalturaCE,代碼行數:10,代碼來源:sftpMgr.class.php

示例13: connect

 /**
  *
  * @throws \Exception
  * @return boolean
  */
 public function connect()
 {
     $this->session = ssh2_connect($this->config->host, $this->config->port);
     if (false === $this->session) {
         throw new \Exception("Echec de la connexion ssh " . print_r($this->config->toArray(), true));
     }
     $auth = ssh2_auth_pubkey_file($this->session, $this->config->username, $this->config->pubkeyfile, $this->config->privkeyfile);
     if (true !== $auth) {
         throw new \Exception("Echec de l'authentification ssh " . print_r($this->config->toArray(), true));
     }
     return true;
 }
開發者ID:dsi-agpt,項目名稱:minibus,代碼行數:17,代碼來源:ScpClient.php

示例14: connect

 /**
  * Connect to server
  */
 protected function connect()
 {
     $this->session = ssh2_connect($this->hostname);
     switch ($this->authType) {
         case self::AUTH_PASSWORD:
             ssh2_auth_password($this->session, $this->user, $this->password);
             break;
         case self::AUTH_KEY:
             ssh2_auth_pubkey_file($this->session, $this->user, $this->pubKey, $this->privKey, $this->password);
             break;
     }
 }
開發者ID:p13eater,項目名稱:backup-lib,代碼行數:15,代碼來源:SSH2.php

示例15: connect

 public function connect()
 {
     $this->connection = @ssh2_connect($this->hostname, $this->port, array('hostkey' => 'ssh-rsa'));
     $fingerprint = ssh2_fingerprint($this->connection, SSH2_FINGERPRINT_SHA1 | SSH2_FINGERPRINT_HEX);
     if (!@ssh2_auth_pubkey_file($this->connection, $this->username, $this->pubKeyFile, $this->privKeyFile)) {
         throw new Exception("Authentification Failed");
     }
     $this->sftpSession = @ssh2_sftp($this->connection);
     if (!$this->sftpSession) {
         throw new Exception("Could not initialize SFTP subsystem.");
     }
 }
開發者ID:phpcommerce,項目名稱:php-ratepay,代碼行數:12,代碼來源:SFTPClient.php


注:本文中的ssh2_auth_pubkey_file函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。