Chilkat HOME Android™ ASP Visual Basic VB.NET C# iOS (IPhone) Objective-C C++ C Unicode C++ Unicode C MFC Delphi DLL Delphi ActiveX FoxPro Java Perl PHP Extension PHP ActiveX Python PowerShell Ruby SQL Server VBScript
SSH -- Running Commands that Prompt for Additional Input, such as "su"Demonstrates how to run a shell command via SSH where the shell command prompts for additional input from the client. This example demonstrates "su". Downloads: MS Windows Visual C/C++ Libraries Linux/CentOS C/C++ Libraries MAC OS X C/C++ Libraries Solaris C/C++ Libraries C++ Builder Libraries FreeBSD C++ Libraries HP-UX C++ Libraries BlackBerry QNX C++ Libraries // Needs #include <CkSsh.h> CkString strOut; // Important: It is helpful to send the contents of the // ssh.LastErrorText property when requesting support. CkSsh ssh; // Any string automatically begins a fully-functional 30-day trial. bool success; success = ssh.UnlockComponent("30-day trial"); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } const char * hostname; long port; // Hostname may be an IP address or hostname: hostname = "192.168.1.117"; port = 22; // Keep a session log, which is available via the SessionLog // property: ssh.put_KeepSessionLog(true); success = ssh.Connect(hostname,port); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // When reading, if no additional data arrives for more than // 5 seconds, then abort: ssh.put_IdleTimeoutMs(5000); // SSH Server Authentication // If there is no login/password required, you must still call // AuthenticatePw and use any values for login/password. success = ssh.AuthenticatePw("chilkat","myPassword"); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Open a session channel. long channelNum; channelNum = ssh.OpenSessionChannel(); if (channelNum < 0) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Request a pseudo-terminal const char * termType; termType = "dumb"; long widthInChars; widthInChars = 120; long heightInChars; heightInChars = 40; long pixWidth; pixWidth = 0; long pixHeight; pixHeight = 0; success = ssh.SendReqPty(channelNum,termType,widthInChars,heightInChars,pixWidth,pixHeight); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Start a shell on the channel: success = ssh.SendReqShell(channelNum); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Send the su command. // (The SSH server I'm using for testing is a Linux Ubuntu // system running OpenSSH. It is important in this case to send a bare-LF // and not a CRLF.) const char * cmd; cmd = "su\n"; success = ssh.ChannelSendString(channelNum,cmd,"ansi"); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Read until we get the prompt for the password: success = ssh.ChannelReceiveUntilMatch(channelNum,"Password:","ansi",true); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Display what we've received so far: strOut.append(ssh.GetReceivedText(channelNum,"ansi")); strOut.append("\r\n"); // Send the password. // Again, make sure it uses a bare-LF and not a CRLF. const char * password; password = "myPassword\n"; success = ssh.ChannelSendString(channelNum,password,"ansi"); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Read the response until we get the shell prompt (assuming it's successful) // In my case, the shell prompt is: "root@ubuntu:/home/chilkat# " // It will be different in your case. success = ssh.ChannelReceiveUntilMatch(channelNum,"root@ubuntu:/home/chilkat#","ansi",true); if (success != true) { // Check the last-error information and the session log... strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); // Check to see what was received. strOut.append(ssh.GetReceivedText(channelNum,"ansi")); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Display what we've received so far. This clears // the internal receive buffer, which is important. // After we send the command, we'll be reading until // the next command prompt. If the command prompt // is already in the internal receive buffer, we'll think we're // already finished... strOut.append(ssh.GetReceivedText(channelNum,"ansi")); strOut.append("\r\n"); // Send a command. In this case, we are sending the "ls" command: cmd = "ls\n"; success = ssh.ChannelSendString(channelNum,cmd,"ansi"); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Read until the next command prompt: success = ssh.ChannelReceiveUntilMatch(channelNum,"root@ubuntu:/home/chilkat#","ansi",true); if (success != true) { // Check the last-error information and the session log... strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); // Check to see what was received. strOut.append(ssh.GetReceivedText(channelNum,"ansi")); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Display the command output: strOut.append(ssh.GetReceivedText(channelNum,"ansi")); strOut.append("\r\n"); // You may continue sending additional commands. // The technique is: send the command, read until the next command prompt, // and then fetch/clear the internal receive buffer. // We're done, so shut it down.. // Send an EOF. This tells the server that no more data will // be sent on this channel. The channel remains open, and // the SSH client may still receive output on this channel. success = ssh.ChannelSendEof(channelNum); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Close the channel: success = ssh.ChannelSendClose(channelNum); if (success != true) { strOut.append(ssh.lastErrorText()); strOut.append("\r\n"); strOut.append(ssh.sessionLog()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Disconnect ssh.Disconnect(); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); |
© 2000-2013 Chilkat Software, Inc. All Rights Reserved.