sshj を使用してリモート サーバーに接続し、いくつかのコマンドを実行しようとしています。実行しようとしているコマンドは次のとおりです。1.ユーザー名とパスワードを入力してパテでログオンします2.次にsudo su - oracle 3.次にパスワードを再度入力します4.次に「sqlplus /nolog」5.次に「sysdbaとして接続」6 . 次にいくつかの sql コマンドを実行します 7. その後、終了して imdmp を実行します
これについて最善/最も簡単な方法を探しています。これが私がこれまでに行ったことです。
私
mport java.io.IOException;
import java.util.concurrent.TimeUnit;
import net.schmizz.sshj.SSHClient;
import net.schmizz.sshj.common.Base64.OutputStream;
import net.schmizz.sshj.common.IOUtils;
import net.schmizz.sshj.connection.channel.direct.Session;
import net.schmizz.sshj.connection.channel.direct.Session.Command;
import net.schmizz.sshj.transport.verification.PromiscuousVerifier;
public class FileCreator {
public static void main(String[] args) throws IOException {
final SSHClient client = new SSHClient();
client.addHostKeyVerifier(new PromiscuousVerifier());
client.connect("192.168.x.x");
client.authPassword("username", "password");
Session session = client.startSession();
Command cmd = session.exec("sudo su - oracle");
cmd.join(1, TimeUnit.SECONDS);
session.close();
session = client.startSession();
Command cmd21 = session.exec("password");
cmd21.join(1, TimeUnit.SECONDS);
session.close();
session = client.startSession();
Command cmd3 = session.exec("1");
cmd3.join(1, TimeUnit.SECONDS);
session.close();
session = client.startSession();
Command cmd4 = session.exec("sqlplus /nolog");
cmd4.join(1, TimeUnit.SECONDS);
session.close();
session = client.startSession();
Command cmd5 = session.exec("connect / as sysdba");
cmd5.join(1, TimeUnit.SECONDS);
session.close();
session = client.startSession();
Command cmd2 = session.exec("drop user STN_x cascade");
cmd2.join(1, TimeUnit.SECONDS);
session.close();
session = client.startSession();
Command cmd20 = session.exec("drop user STN_x_dba cascade;");
cmd20.join(1, TimeUnit.SECONDS);
session.close();
session = client.startSession();
Command cmd6 = session.exec("");
cmd6.join(1, TimeUnit.SECONDS);
session.close();
client.disconnect();
}
}