所以,我有一个使用org.apache.commons.net.telnet.TelnetClient类的类。它尝试发送命令并读取响应。
public class AutomatedTelnetClient
{
private TelnetClient telnet = new TelnetClient();
private InputStream in;
private PrintStream out;
private String prompt = "$";
public AutomatedTelnetClient(String server, String user, String password)
{
try
{
EchoOptionHandler echoopt = new EchoOptionHandler(false, false, false, false);
telnet.addOptionHandler(echoopt);
// Connect to the specified server
telnet.connect(server, 23);
// Get input and output stream references
in = telnet.getInputStream();
out = new PrintStream(telnet.getOutputStream());
// Log the user on
readUntil("login: ");
write(user);
readUntil("Password: ");
write(password);
// Advance to a prompt
readUntil(prompt + " ");
}
catch (Exception e)
{
e.printStackTrace();
}
}
public void su(String password)
{
try
{
write("su");
readUntil("Password: ");
write(password);
prompt = "#";
readUntil(prompt + " ");
}
catch (Exception e)
{
e.printStackTrace();
}
}
public String readUntil(String pattern)
{
try
{
char lastChar = pattern.charAt(pattern.length() - 1);
StringBuffer sb = new StringBuffer();
boolean found = false;
char ch = (char) in.read();
while (true)
{
System.out.print(ch);
sb.append(ch);
if (ch == lastChar)
{
if (sb.toString().endsWith(pattern))
{
return sb.toString();
}
}
ch = (char) in.read();
}
}
catch (Exception e)
{
e.printStackTrace();
}
return null;
}
public void write(String value)
{
try
{
out.println(value);
out.flush();
System.out.println(value);
}
catch (Exception e)
{
e.printStackTrace();
}
}
public String sendCommand(String command)
{
try
{
write(command);
return readUntil(prompt + " ");
}
catch (Exception e)
{
e.printStackTrace();
}
return null;
}
public void disconnect()
{
try
{
telnet.disconnect();
}
catch (Exception e)
{
e.printStackTrace();
}
}
public static void main(String[] args)
{
try
{
AutomatedTelnetClient telnet = new AutomatedTelnetClient(
"...", "...", "...");
System.out.println("Got Connection...");
System.out.println("run command");
telnet.sendCommand("ls ");
telnet.sendCommand("cd netConf");
telnet.sendCommand("ls ");
telnet.sendCommand("cd lanSetup");
telnet.sendCommand("ls ");
telnet.sendCommand("cd dhcpd");
telnet.sendCommand("show interface 2");
telnet.disconnect();
System.out.println("DONE");
}
catch (Exception e)
{
e.printStackTrace();
}
}
}问题是,当我发送命令时,响应会以某种回声作为前缀。例如,当我发送ls命令时,这是我读取的响应
[mls
....我试过在how to disable echo上搜索,但似乎没有人知道答案。所以我决定问问这个社区。有人知道如何禁用这个回声吗?
编辑
查看EchoOptionHandler的源代码让我很困惑。为什么子协商方法只返回null
发布于 2011-06-24 13:48:59
有趣的问题。总结一下我的努力:我没有让它正常工作,但以下是我的一些发现:
不能将IAC DON'T ECHO直接写入数据通道,这是通过命令和选项完成的,如下例所示
int[] msg = {TelnetCommand.DONT,TelnetOption.ECHO};
telnet.sendSubnegotiation(msg);您可以在连接安装期间注册telnet.registerNotifHandler(new MyNotificationHandler());来调试命令。
public class MyNotificationHandler implements TelnetNotificationHandler
{
@Override
public void receivedNegotiation(int negotiation_code, int option_code)
{
System.out.println("--->"+get(negotiation_code)+" "
+TelnetOption.getOption(option_code));
}
private String get(int i)
{
if(i==TelnetNotificationHandler.RECEIVED_DO){return "RECEIVED_DO";}
else if(i==TelnetNotificationHandler.RECEIVED_DONT){return "RECEIVED_DONT";}
else if(i==TelnetNotificationHandler.RECEIVED_WILL){return "RECEIVED_WILL";}
else if(i==TelnetNotificationHandler.RECEIVED_WONT){return "RECEIVED_WONT";}
else if(i==TelnetNotificationHandler.RECEIVED_COMMAND)
{return "RECEIVED_COMMAND";}
return "UNKNOWN";
}
}发布于 2011-06-30 11:57:06
默认情况下,TelnetClient向远程系统指示它是"vt100“终端。[m是VT100转义序列的一部分。在构造TelnetClient时,将"dumb"作为第一个参数传递,以指示终端不支持转义序列。所以
TelnetClient telnet = new TelnetClient("dumb");更新:
它可能是远程上的shell提示符设置为彩色显示。如果运行"echo $PS1“,您将看到提示符设置为什么,可能如下所示:
\[\e]2;\u@\h : \w\007\]\[\e[39m\e[0;49m\][\[\e[1;34m\]\u\[\e[0;37m\]@\[\e[0;32m\]\h\[\e[0;36m\] \[\e[0;33m\]\w\[\e[39m\e[0;49m\]]$ 它在我的终端上显示为" user @host目录$“,括号和美元符号为白色,用户为蓝色,主机为绿色,目录为黄色。对人很好,但对机器不好。
登录后,立即发送"PS1='$ '\n“。这将把提示符设置为一个美元符号,后面跟着一个没有任何额外序列的空格。
发布于 2011-07-20 09:38:35
你查过expect4J了吗?
URL - http://code.google.com/p/expect4j
这实际上是expect库的java实现。
https://stackoverflow.com/questions/6410579
复制相似问题