mirror of
https://github.com/phpseclib/phpseclib.git
synced 2025-01-28 01:28:27 +00:00
- update SSH1 logging and disconnecting
- add better support for an as-yet-to-be-written SCP class - update example of read() git-svn-id: http://phpseclib.svn.sourceforge.net/svnroot/phpseclib/trunk@158 21d32557-59b3-4da0-833f-c5933fad653e
This commit is contained in:
parent
c61b3f9da9
commit
34cdb781cc
@ -30,9 +30,9 @@
|
|||||||
* exit('Login Failed');
|
* exit('Login Failed');
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
* echo $ssh->read('%');
|
* echo $ssh->read('username@username:~$');
|
||||||
* $ssh->write("ls -la\r\n");
|
* $ssh->write("ls -la\n");
|
||||||
* echo $ssh->read('%');
|
* echo $ssh->read('username@username:~$');
|
||||||
* ?>
|
* ?>
|
||||||
* </code>
|
* </code>
|
||||||
*
|
*
|
||||||
@ -444,6 +444,7 @@ class Net_SSH1 {
|
|||||||
16 => 'NET_SSH1_CMSG_STDIN_DATA',
|
16 => 'NET_SSH1_CMSG_STDIN_DATA',
|
||||||
17 => 'NET_SSH1_SMSG_STDOUT_DATA',
|
17 => 'NET_SSH1_SMSG_STDOUT_DATA',
|
||||||
18 => 'NET_SSH1_SMSG_STDERR_DATA',
|
18 => 'NET_SSH1_SMSG_STDERR_DATA',
|
||||||
|
19 => 'NET_SSH1_CMSG_EOF',
|
||||||
20 => 'NET_SSH1_SMSG_EXITSTATUS',
|
20 => 'NET_SSH1_SMSG_EXITSTATUS',
|
||||||
33 => 'NET_SSH1_CMSG_EXIT_CONFIRMATION'
|
33 => 'NET_SSH1_CMSG_EXIT_CONFIRMATION'
|
||||||
);
|
);
|
||||||
@ -644,6 +645,12 @@ class Net_SSH1 {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// remove the username and password from the last logged packet
|
||||||
|
if (defined('NET_SSH1_LOGGING') && NET_SSH1_LOGGING == NET_SSH1_LOG_COMPLEX) {
|
||||||
|
$data = pack('CNa*', NET_SSH1_CMSG_AUTH_PASSWORD, strlen('password'), 'password');
|
||||||
|
$this->message_log[count($this->message_log) - 1] = $data; // zzzzz
|
||||||
|
}
|
||||||
|
|
||||||
$response = $this->_get_binary_packet();
|
$response = $this->_get_binary_packet();
|
||||||
|
|
||||||
if ($response[NET_SSH1_RESPONSE_TYPE] == NET_SSH1_SMSG_SUCCESS) {
|
if ($response[NET_SSH1_RESPONSE_TYPE] == NET_SSH1_SMSG_SUCCESS) {
|
||||||
@ -684,23 +691,6 @@ class Net_SSH1 {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// connect using the sample parameters in protocol-1.5.txt.
|
|
||||||
// according to wikipedia.org's entry on text terminals, "the fundamental type of application running on a text
|
|
||||||
// terminal is a command line interpreter or shell". thus, opening a terminal session to run the shell.
|
|
||||||
$data = pack('CNa*N4C', NET_SSH1_CMSG_REQUEST_PTY, strlen('vt100'), 'vt100', 24, 80, 0, 0, NET_SSH1_TTY_OP_END);
|
|
||||||
|
|
||||||
if (!$this->_send_binary_packet($data)) {
|
|
||||||
user_error('Error sending SSH_CMSG_REQUEST_PTY', E_USER_NOTICE);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$response = $this->_get_binary_packet();
|
|
||||||
|
|
||||||
if ($response[NET_SSH1_RESPONSE_TYPE] != NET_SSH1_SMSG_SUCCESS) {
|
|
||||||
user_error('Expected SSH_SMSG_SUCCESS', E_USER_NOTICE);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$data = pack('CNa*', NET_SSH1_CMSG_EXEC_CMD, strlen($cmd), $cmd);
|
$data = pack('CNa*', NET_SSH1_CMSG_EXEC_CMD, strlen($cmd), $cmd);
|
||||||
|
|
||||||
if (!$this->_send_binary_packet($data)) {
|
if (!$this->_send_binary_packet($data)) {
|
||||||
@ -743,6 +733,9 @@ class Net_SSH1 {
|
|||||||
*/
|
*/
|
||||||
function _initShell()
|
function _initShell()
|
||||||
{
|
{
|
||||||
|
// connect using the sample parameters in protocol-1.5.txt.
|
||||||
|
// according to wikipedia.org's entry on text terminals, "the fundamental type of application running on a text
|
||||||
|
// terminal is a command line interpreter or shell". thus, opening a terminal session to run the shell.
|
||||||
$data = pack('CNa*N4C', NET_SSH1_CMSG_REQUEST_PTY, strlen('vt100'), 'vt100', 24, 80, 0, 0, NET_SSH1_TTY_OP_END);
|
$data = pack('CNa*N4C', NET_SSH1_CMSG_REQUEST_PTY, strlen('vt100'), 'vt100', 24, 80, 0, 0, NET_SSH1_TTY_OP_END);
|
||||||
|
|
||||||
if (!$this->_send_binary_packet($data)) {
|
if (!$this->_send_binary_packet($data)) {
|
||||||
@ -808,16 +801,15 @@ class Net_SSH1 {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$match = $expect;
|
||||||
while (true) {
|
while (true) {
|
||||||
if ($mode != NET_SSH1_READ_REGEX) {
|
if ($mode == NET_SSH1_READ_REGEX) {
|
||||||
$pos = strpos($this->interactiveBuffer, $expect);
|
preg_match($expect, $this->interactiveBuffer, $matches);
|
||||||
} else {
|
$match = $matches[0];
|
||||||
$pos = preg_match($expect, $this->interactiveBuffer, $matches) ?
|
|
||||||
strpos($this->interactiveBuffer, $matches[0]) :
|
|
||||||
false;
|
|
||||||
}
|
}
|
||||||
|
$pos = strpos($this->interactiveBuffer, $match);
|
||||||
if ($pos !== false) {
|
if ($pos !== false) {
|
||||||
return $this->_string_shift($this->interactiveBuffer, $pos + 1);
|
return $this->_string_shift($this->interactiveBuffer, $pos + strlen($match));
|
||||||
}
|
}
|
||||||
$response = $this->_get_binary_packet();
|
$response = $this->_get_binary_packet();
|
||||||
$this->interactiveBuffer.= substr($response[NET_SSH1_RESPONSE_DATA], 4);
|
$this->interactiveBuffer.= substr($response[NET_SSH1_RESPONSE_DATA], 4);
|
||||||
@ -921,7 +913,18 @@ class Net_SSH1 {
|
|||||||
function _disconnect($msg = 'Client Quit')
|
function _disconnect($msg = 'Client Quit')
|
||||||
{
|
{
|
||||||
if ($this->bitmap) {
|
if ($this->bitmap) {
|
||||||
$data = pack('CNa*', NET_SSH1_MSG_DISCONNECT, strlen($msg), $msg);
|
$data = pack('C', NET_SSH1_CMSG_EOF);
|
||||||
|
$this->_send_binary_packet($data);
|
||||||
|
|
||||||
|
$response = $this->_get_binary_packet();
|
||||||
|
switch ($response[NET_SSH1_RESPONSE_TYPE]) {
|
||||||
|
case NET_SSH1_SMSG_EXITSTATUS:
|
||||||
|
$data = pack('C', NET_SSH1_CMSG_EXIT_CONFIRMATION);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$data = pack('CNa*', NET_SSH1_MSG_DISCONNECT, strlen($msg), $msg);
|
||||||
|
}
|
||||||
|
|
||||||
$this->_send_binary_packet($data);
|
$this->_send_binary_packet($data);
|
||||||
fclose($this->fsock);
|
fclose($this->fsock);
|
||||||
$this->bitmap = 0;
|
$this->bitmap = 0;
|
||||||
@ -1004,6 +1007,15 @@ class Net_SSH1 {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (defined('NET_SSH1_LOGGING')) {
|
||||||
|
$temp = isset($this->protocol_flags[ord($data[0])]) ? $this->protocol_flags[ord($data[0])] : 'UNKNOWN';
|
||||||
|
$this->protocol_flags_log[] = '-> ' . $temp .
|
||||||
|
' (' . round($stop - $start, 4) . 's)';
|
||||||
|
if (NET_SSH1_LOGGING == NET_SSH1_LOG_COMPLEX) {
|
||||||
|
$this->message_log[] = substr($data, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$length = strlen($data) + 4;
|
$length = strlen($data) + 4;
|
||||||
|
|
||||||
$padding_length = 8 - ($length & 7);
|
$padding_length = 8 - ($length & 7);
|
||||||
@ -1025,15 +1037,6 @@ class Net_SSH1 {
|
|||||||
$result = strlen($packet) == fputs($this->fsock, $packet);
|
$result = strlen($packet) == fputs($this->fsock, $packet);
|
||||||
$stop = strtok(microtime(), ' ') + strtok('');
|
$stop = strtok(microtime(), ' ') + strtok('');
|
||||||
|
|
||||||
if (defined('NET_SSH1_LOGGING')) {
|
|
||||||
$temp = isset($this->protocol_flags[ord($data[0])]) ? $this->protocol_flags[ord($data[0])] : 'UNKNOWN';
|
|
||||||
$this->protocol_flags_log[] = '-> ' . $temp .
|
|
||||||
' (' . round($stop - $start, 4) . 's)';
|
|
||||||
if (NET_SSH1_LOGGING == NET_SSH1_LOG_COMPLEX) {
|
|
||||||
$this->message_log[] = substr($data, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,9 +35,9 @@
|
|||||||
* exit('Login Failed');
|
* exit('Login Failed');
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
* echo $ssh->read('%');
|
* echo $ssh->read('username@username:~$');
|
||||||
* $ssh->write("ls -la\r\n");
|
* $ssh->write("ls -la\n");
|
||||||
* echo $ssh->read('%');
|
* echo $ssh->read('username@username:~$');
|
||||||
* ?>
|
* ?>
|
||||||
* </code>
|
* </code>
|
||||||
*
|
*
|
||||||
@ -2005,7 +2005,7 @@ class Net_SSH2 {
|
|||||||
* @return Mixed
|
* @return Mixed
|
||||||
* @access private
|
* @access private
|
||||||
*/
|
*/
|
||||||
function _get_channel_packet($client_channel)
|
function _get_channel_packet($client_channel, $skip_extended = false)
|
||||||
{
|
{
|
||||||
if (!empty($this->channel_buffers[$client_channel])) {
|
if (!empty($this->channel_buffers[$client_channel])) {
|
||||||
return array_shift($this->channel_buffers[$client_channel]);
|
return array_shift($this->channel_buffers[$client_channel]);
|
||||||
@ -2074,6 +2074,9 @@ class Net_SSH2 {
|
|||||||
$this->channel_buffers[$client_channel][] = $data;
|
$this->channel_buffers[$client_channel][] = $data;
|
||||||
break;
|
break;
|
||||||
case NET_SSH2_MSG_CHANNEL_EXTENDED_DATA:
|
case NET_SSH2_MSG_CHANNEL_EXTENDED_DATA:
|
||||||
|
if ($skip_extended) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
if ($client_channel == NET_SSH2_CHANNEL_EXEC) {
|
if ($client_channel == NET_SSH2_CHANNEL_EXEC) {
|
||||||
$this->_send_channel_packet($client_channel, chr(0));
|
$this->_send_channel_packet($client_channel, chr(0));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user