スクリプトを実行するrunshellscriptメソッドを呼び出すJavaクラスがあります。mysqlではうまく機能しましたが、psqlではうまく機能しない理由がわからないようです。これが私のrunshellメソッドの抜粋:
public class RunShellScript {
public static void runShellScript (String unixCommand)
{
try {
Runtime runtime=Runtime.getRuntime();
//Process process=runtime.exec(new String [] { "/bin/csh", "-c", unixCommand});
Process process=runtime.exec(new String [] {unixCommand});
InputStream stderr=process.getErrorStream();
InputStreamReader isr=new InputStreamReader (stderr);
BufferedReader br=new BufferedReader (isr);
String line=null;
System.out.println("<ERROR>");
while((line=br.readLine())!=null)
System.out.println(line);
System.out.println(line);
int exitVal=process.waitFor();
System.out.println("Process exitValue:" + exitVal);
}
catch (Throwable t)
{
t.printStackTrace();
}
問題は、これをマウスクリックイベントの背後に置くと、コマンドが見つからないと表示されることです。これが覚書イベントの前のコードです
private void jMenuItem13MousePressed(Java.awt.event.MouseEvent evt) {
String shellCommand="vobs/tools/Scripts/DataValidation/mysqlconnection.csh";
RunShellScript.runShellScript(shellCommand);
// TODO add your handling code here:
}
奇妙なことに、スクリプトが存在するディレクトリに直接移動して./mysqlconnectionと入力すると、スクリプトが機能します。しかし、mysqlconnectionと入力すると、コマンドが見つかりませんと表示されます。どういうわけか、スクリプト名がコマンドとして認識されませんか?
Autosys [autosys-> Shell-> Java-> ProcessBuilder]からシェルスクリプト(システムとユーザーが作成したコマンドを含む)を呼び出すときに直面した問題に似ているようです。ProcessBuilder
はコマンドから実行され、Linuxマシンで実行されます。
これは、Linuxボックスにログインしてスクリプトを実行すると機能しましたが、autosysから呼び出すと機能しませんでした。
実際の問題は_$PATH
_変数であり、ユーザーが作成したコマンドのディレクトリで設定されていません。
LinuxマシンとAutosysから実行するときに$ PATH変数をシェルスクリプトでエコーします。Autosysから実行するときに$ PATH変数が正しく設定されていません。これは、機能する$ PATH変数にユーザーコマンドパスを追加した後です。which (cmd)
はコマンドのディレクトリを返し、このディレクトリに$ PATHを追加すると、機能します。
スクリプトパスを$ PATHに追加して、アプリケーションから実行してみてください
UNIXライクなシステムでは、シェルは、現在のディレクトリへの明確なパスが指定されている場合にのみ、現在のディレクトリにあるプログラムを実行します。これは、攻撃者が、たとえば、/bin/ls
にある実際のls
プログラムの代わりに実行されるls
という名前のプログラムをホームディレクトリに置くことを防ぐためです。したがって、現在のディレクトリはPATHから除外されます。
また、移動してみてください
int exitVal=process.waitFor();
while
ループの上に。