| org.apache.commons.net.bsd.RExecClient org.apache.commons.net.bsd.RCommandClient org.apache.commons.net.bsd.RLoginClient
RLoginClient | public class RLoginClient extends RCommandClient (Code) | | RLoginClient is very similar to
org.apache.commons.net.bsd.RCommandClient ,
from which it is derived, and uses the rcmd() facility implemented
in RCommandClient to implement the functionality of the rlogin command that
first appeared in 4.2BSD Unix. rlogin is a command used to login to
a remote machine from a trusted host, sometimes without issuing a
password. The trust relationship is the same as described in
the documentation for
org.apache.commons.net.bsd.RCommandClient .
As with virtually all of the client classes in org.apache.commons.net, this
class derives from SocketClient. But it relies on the connection
methods defined in RcommandClient which ensure that the local Socket
will originate from an acceptable rshell port. The way to use
RLoginClient is to first connect
to the server, call the
RLoginClient.rlogin rlogin() method,
and then
fetch the connection's input and output streams.
Interaction with the remote command is controlled entirely through the
I/O streams. Once you have finished processing the streams, you should
invoke
org.apache.commons.net.bsd.RExecClient.disconnect disconnect() to clean up properly.
The standard output and standard error streams of the
remote process are transmitted over the same connection, readable
from the input stream returned by
org.apache.commons.net.bsd.RExecClient.getInputStream getInputStream() . Unlike RExecClient and RCommandClient, it is
not possible to tell the rlogind daemon to return the standard error
stream over a separate connection.
org.apache.commons.net.bsd.RExecClient.getErrorStream getErrorStream() will always return null.
The standard input of the remote process can be written to through
the output stream returned by
org.apache.commons.net.bsd.RExecClient.getOutputStream getOutputSream() .
author: Daniel F. Savarese See Also: org.apache.commons.net.SocketClient See Also: RExecClient See Also: RCommandClient |
Field Summary | |
final public static int | DEFAULT_PORT The default rlogin port. |
Constructor Summary | |
public | RLoginClient() The default RLoginClient constructor. |
Method Summary | |
public void | rlogin(String localUsername, String remoteUsername, String terminalType, int terminalSpeed) Logins into a remote machine through the rlogind daemon on the server
to which the RLoginClient is connected. | public void | rlogin(String localUsername, String remoteUsername, String terminalType) Same as the other rlogin method, but no terminal speed is defined. |
DEFAULT_PORT | final public static int DEFAULT_PORT(Code) | | The default rlogin port. Set to 513 in BSD Unix and according
to RFC 1282.
|
RLoginClient | public RLoginClient()(Code) | | The default RLoginClient constructor. Initializes the
default port to DEFAULT_PORT .
|
rlogin | public void rlogin(String localUsername, String remoteUsername, String terminalType, int terminalSpeed) throws IOException(Code) | | Logins into a remote machine through the rlogind daemon on the server
to which the RLoginClient is connected. After calling this method,
you may interact with the remote login shell through its standard input
and output streams. Standard error is sent over the same stream as
standard output. You will typically be able to detect
the termination of the remote login shell after reaching end of file
on its standard output (accessible through
RLoginClient.getInputStream getInputStream() . Disconnecting
from the server or closing the process streams before reaching
end of file will terminate the remote login shell in most cases.
If user authentication fails, the rlogind daemon will request that
a password be entered interactively. You will be able to read the
prompt from the output stream of the RLoginClient and write the
password to the input stream of the RLoginClient.
Parameters: localUsername - The user account on the local machine that istrying to login to the remote host. Parameters: remoteUsername - The account name on the server that isbeing logged in to. Parameters: terminalType - The name of the user's terminal (e.g., "vt100","network", etc.) Parameters: terminalSpeed - The speed of the user's terminal, expressedas a baud rate or bps (e.g., 9600 or 38400) exception: IOException - If the rlogin() attempt fails. The exceptionwill contain a message indicating the nature of the failure. |
rlogin | public void rlogin(String localUsername, String remoteUsername, String terminalType) throws IOException(Code) | | Same as the other rlogin method, but no terminal speed is defined.
|
Methods inherited from org.apache.commons.net.bsd.RCommandClient | InputStream _createErrorStream() throws IOException(Code)(Java Doc) public void connect(InetAddress host, int port, InetAddress localAddr) throws SocketException, BindException, IOException(Code)(Java Doc) public void connect(InetAddress host, int port) throws SocketException, IOException(Code)(Java Doc) public void connect(String hostname, int port) throws SocketException, IOException(Code)(Java Doc) public void connect(String hostname, int port, InetAddress localAddr) throws SocketException, IOException(Code)(Java Doc) public void connect(InetAddress host, int port, InetAddress localAddr, int localPort) throws SocketException, IOException, IllegalArgumentException(Code)(Java Doc) public void connect(String hostname, int port, InetAddress localAddr, int localPort) throws SocketException, IOException, IllegalArgumentException(Code)(Java Doc) public void rcommand(String localUsername, String remoteUsername, String command, boolean separateErrorStream) throws IOException(Code)(Java Doc) public void rcommand(String localUsername, String remoteUsername, String command) throws IOException(Code)(Java Doc)
|
|
|