我无法将安全服务器的一个unix服务器连接到另一个unix服务器。通过ssh从putty我能够轻松连接,但是当我从jsch连接时,我在下面发生错误。
成功的putty步骤 - >连接putty中的server1->成功>使用" ssh user @ ip"
连接server2jsch步骤 - >
连接会话1 - >连接一台服务器//评论 - >在服务器1上运行命令以连接其他服务器
错误: - 由于stdin不是终端,因此不会分配伪终端。 许可被拒绝,请再试一次。 许可被拒绝,请再试一次。 权限被拒绝(公钥,密码,键盘交互)。 ksh:changeme:找不到 退出状态:127
Jsch示例程序 - >
java.util.Properties config = new java.util.Properties();
config.put("StrictHostKeyChecking", "no");
JSch jsch = new JSch();
jsch.setKnownHosts("C://known_hosts.txt");
session=jsch.getSession(user1, server1, 22);
session.setPassword(password1);
session.setConfig(config);
session.connect();
System.out.println("Connected session1");
String command ="ssh"+" "+"user@ip;"+"password" ;
channel=session.openChannel("exec");
((ChannelExec)channel).setCommand(command);
channel.setInputStream(null);
InputStream in=channel.getInputStream();
((ChannelExec)channel).setErrStream(System.err);
channel.connect();
byte[] tmp=new byte[1024];
while(true){
while(in.available()>0){
int i=in.read(tmp, 0, 1024);
if(i<0)break;
System.out.print("server 1"+new String(tmp, 0, i));
}
if(channel.isClosed()){
System.out.println("exit-status: "+channel.getExitStatus());
break;
}
try{Thread.sleep(1000);}catch(Exception ee){}
channel.disconnect();
session.disconnect();
答案 0 :(得分:2)
我正在添加答案的重要部分: -
JSch jsch = new JSch();
jsch.setKnownHosts("C:/My Program Files/eclipse/workspace/StatusTracker/known_hosts.txt");
// jsch.setKnownHosts(knownHostLoc);
//Jump server connection session started
jumpServerSession = jsch.getSession(userid, jump server ip/hostname, 22);
jumpServerSession.setPassword(jump server password);
java.util.Properties config = new java.util.Properties();
config.put("StrictHostKeyChecking", "no");
jumpServerSession.setConfig(config);
jumpServerSession.connect();
System.out.println("The session has been established to "+jump server userid+"@"+jump server name);
int assinged_port = jumpServerSession.setPortForwardingL(0, other server ip, 22);
System.out.println("portforwarding: "+
"localhost:"+assinged_port+" -> "+other server ip+":"+22);
//Main server connection session started
targetServerSession = jsch.getSession(fileBO.getServerUserId(), "127.0.0.1", assinged_port);
targetServerSession.setHostKeyAlias(other server ip);
targetServerSession.setPassword(other server password);
java.util.Properties config1 = new java.util.Properties();
config1.put("StrictHostKeyChecking", "no");
targetServerSession.setConfig(config1);
targetServerSession.connect();
channel = targetServerSession.openChannel("sftp");
channel = targetServerSession.openChannel("exec");
//command want to execute on dest server
((ChannelExec)channel).setCommand("pwd");
channel.setInputStream(null);
InputStream in11=channel.getInputStream();
((ChannelExec)channel).setErrStream(System.err);
channel.connect();
byte[] tmp1=new byte[1024];
while(true){
while(in11.available()>0){
int i1=in11.read(tmp1, 0, 1024);
if(i1<0)break;
System.out.print(new String(tmp1, 0, i1));
}
if(channel.isClosed()){
System.out.println("exit-status: "+channel.getExitStatus());
break;
}
try{Thread.sleep(1000);}catch(Exception ee){}
}
} catch (final JSchException e) {
LOGGER.error(e.getMessage());
}
答案 1 :(得分:0)
代替执行端口转发,您可以在连接之前简单地使用channel.setPty(true)。之后,您可以使用outPutStream提供密码。