gpt4 book ai didi

Java JSch 在远程机器上更改用户并执行命令

转载 作者:太空狗 更新时间:2023-10-29 11:27:31 25 4
gpt4 key购买 nike

我正在尝试连接到主机,然后使用“su - john”更改用户,然后以 john 身份执行命令。只使用 JSch 有可能吗?

问题是,在我创建 session 并打开 channel 并执行上述命令后,它应该请求密码,但没有任何反应。

这是我连接到远程机器的方式:

String address = "myremote.computer.com";

JSch jsch = new JSch();
String user = "tom";
String host = address;
String password = "l33tpaSSw0rd";
Session session = jsch.getSession( user, host, 22 );
java.util.Properties config = new java.util.Properties();
config.put( "StrictHostKeyChecking", "no" );
session.setConfig( config );
session.setPassword( password );

session.connect();

然后我通过 runSshCommand() 方法执行命令,如下所示:

try
{
Channel channel = session.openChannel( "exec" );
channel.setInputStream( null );
channel.setOutputStream( System.out );

( (ChannelExec) channel ).setCommand( command );

channel.connect();

InputStream in = channel.getInputStream();

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( new String( tmp, 0, i ) );
}
if ( channel.isClosed() )
{
break;
}
try
{
Thread.sleep( 1000 );
}
catch ( Exception ee )
{
}
}
channel.disconnect();
}
catch ( Exception e )
{
e.printStackTrace();
}

当我更改用户时,我是否必须创建另一个 channel ,或者如何让它发挥作用?

因为如果我用

runSshCommand("su - john",session);
runSshCommand("tail -1 ~/mylog.log",session);

它只是执行“su”命令,但没有完成用户的更改,之后执行“tail”会导致错误,因为“tom”还没有得到文件:/

基本上我希望我的应用程序连接到机器、更改用户、读取一个文件并返回数据。任何人都可以解释一下吗?

最佳答案

这里有几个问题。

首先,SSH 连接中的每个 channel 都独立于其他 channel ,每个 exec channel 中的命令在其自己的 shell(命令行解释器)中执行。因此,您在一个 channel 中所做的任何更改都不会对其他 channel 产生任何影响。你也不能做这样的事情:

runSshCommand("cd Documents", session);
runSshCommand("ls -l", session);

(实际上你可以这样做,但它不会显示 Documents 目录的内容,而是显示主目录的内容。)

对于 cd,您可以通过将两个命令作为一个“命令”传递来变通,以在相同的 exec channel 中使用:

runSshCommand("cd Documents; ls -l");

(除了 ;,您还可以使用换行符 \n 来分隔命令,或者您的 shell 接受的任何其他内容。)

对于su,这是行不通的,我们来到了第二个问题

su 不是更改当前 shell 状态的命令(如 cd),而是在现有 shell 中打开新 shell 的命令。只有当您离开由 su 启动的外壳时(例如,通过 exitlogout 或文件结束),它才会返回外壳, 然后你又是以前的那个用户了。

要将命令传递给“内壳”,您必须将它们传递给壳输入。或者使用 su-c (--command) 参数:

runSshCommand("su -c 'tail -1 ~/mylog.log' - john ",session);

然后您可能会遇到第三个问题:su 将询问 john 的密码,并且可能拒绝从标准输入读取它,但尝试从终点站。而且您的 channel 没有伪终端。你可以尝试使用cannel.setPty(true)然后实际将您的密码写入输出流,但我不确定这是否有效。

替代方案: 您可以使用 sudo 代替 su -c,它可以配置为不要求某些命令输入密码,并且用户(否则您将再次遇到相同的终端问题)。或者您可以直接以 john 身份登录,或者使日志文件对 tom 可读。 (另外,我希望你的真实密码比源代码中的密码更好。)

关于Java JSch 在远程机器上更改用户并执行命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16343117/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com