From: =?iso-8859-2?Q?Radek_Krej=E8a?= on 4 Apr 2010 18:26 Hello, I am trying send command to remote host over ssh with sockets. But I need to set up username/password. I am trying to modify this script (from www.php..net - function fsockopen), but I dont know, where set username/password because I got this message: Bad protocol version identification 'password' from ip Library ssh2 is not currentu userfull for me, because I am not admin of server. Thank you Radek <?php /************************************************************ * Author: Richard Lajaunie * Mail : richard.lajaunie(a)cote-azur.cci.fr * * subject : this script retreive all mac-addresses on all ports * of a Cisco 3548 Switch by a telnet connection * * base on the script by: xbensemhoun at t-systems dot fr on the same page **************************************************************/ if ( array_key_exists(1, $argv) ){ $cfgServer = $argv[1]; }else{ echo "ex: 'php test.php 10.0.0.0' \n"; exit; } $cfgPort = 23; //port, 22 if SSH $cfgTimeOut = 10; $usenet = fsockopen($cfgServer, $cfgPort, $errno, $errstr), $cfgTimeOut); if(!$usenet){ echo "Connexion failed\n"; exit(); }else{ echo "Connected\n"; fputs ($usenet, "password\r\n"); fputs ($usenet, "en\r\n"); fputs ($usenet, "password\r\n"); fputs ($usenet, "sh mac-address-table\r\n"); fputs ($usenet, " "); // this space bar is this for long output // this skip non essential text $j = 0; while ($j<16){ fgets($usenet, 128); $j++; } stream_set_timeout($usenet, 2); // set the timeout for the fgets $j = 0; while (!feof($usenet)){ $ret = fgets($usenet, 128); $ret = str_replace("\r", '', $ret); $ret = str_replace("\n", "", $ret); if (ereg("FastEthernet", $ret)){ echo "$ret \n"; } if (ereg('--More--', $ret) ){ fputs ($usenet, " "); // for following page } $info = stream_get_meta_data($usenet); if ($info['timed_out']) { $j++; } if ($j >2){ fputs ($usenet, "lo"); break; } } } echo "End.\r\n"; ?>
From: =?utf-8?B?UmFkZWsgS3JlasSNYQ==?= on 5 Apr 2010 03:56 Hello, thank you for response, more in you text: Instead of ssh, you could use telnet to connect to the Cisco router (which incidentally runs on port 23, but is likely to be disabled on I want to use my script against FreeBSD router and against RouterOS so I need ssh. I can use system function to call ssh command, but I can try it over php tools. Or if you do not like the idea of sending clear-text passwords to the router, you might want to learn about proc_open() (or popen()) and use the native ssh utility that most likely is present on the server, taking great care to READ THE MANUAL for the ssh command, because you most likely do _not_ want it to spit out ANSI-escapes to you script. It will be probably better way than system function. If I fail with using sockets I use this. Thank you very much. Radek
From: "Bob McConnell" on 5 Apr 2010 08:56 From: Radek Krejca > I am trying send command to remote host over ssh with sockets. But > I need to set up username/password. I am trying to modify this script > (from www.php.net - function fsockopen), but I dont know, where set > username/password because I got this message: > Bad protocol version identification 'password' from ip > > Library ssh2 is not currentu userfull for me, because I am not > admin of server. > <?php > /************************************************************ > * Author: Richard Lajaunie > * Mail : richard.lajaunie(a)cote-azur.cci.fr > * > * subject : this script retreive all mac-addresses on all ports > * of a Cisco 3548 Switch by a telnet connection > * > * base on the script by: xbensemhoun at t-systems dot fr on the same page > **************************************************************/ > > if ( array_key_exists(1, $argv) ){ > $cfgServer = $argv[1]; > }else{ > echo "ex: 'php test.php 10.0.0.0' \n"; > exit; > } > > $cfgPort = 23; //port, 22 if SSH > $cfgTimeOut = 10; > > $usenet = fsockopen($cfgServer, $cfgPort, $errno, $errstr), $cfgTimeOut); > > if(!$usenet){ > echo "Connexion failed\n"; > exit(); > }else{ > echo "Connected\n"; > fputs ($usenet, "password\r\n"); > fputs ($usenet, "en\r\n"); > fputs ($usenet, "password\r\n"); > fputs ($usenet, "sh mac-address-table\r\n"); > fputs ($usenet, " "); // this space bar is this for long output > Well, in the first place, you don't simply send a series of words to the other end after opening the connection. Most protocols define a conversation that happens between the two ends of a new connection. So you have to wait for the server to send you a welcome message with a prompt and reply to that. Then wait for the next prompt and reply to it. So instead of just blasting out these strings, you need a receive loop and parser to interpret what the server is saying to you. Once you know what it says at each step you can decide how to respond. SSH adds another layer in front of this to select key exchanges, ciphers, hashes, etc. You don't want to write an SSH client. It can take days just to read and understand the protocol definition. A few minutes on Google should produce some useable examples of clients for various protocols. It shouldn't take much work to read a basic Telnet client written in Perl and transpose it into PHP. Bob McConnell
|
Pages: 1 Prev: $_SERVER['PHP_AUTH_USER'] has gone Next: Fwd: Medical Task Force |