create alias if not exists orionssh2_exec as $$
import java.io.*;
import java.util.*;
import java.sql.*;
import org.h2.tools.*;
import java.net.*;
import com.trilead.ssh2.*;
@CODE
String orionssh2_exec(String host, String user,
String password, String cmd)
throws Exception
{
if( host == null ){
throw new Exception("server is not specified.");
}
if( user == null ){
throw new Exception("user is not specified.");
}
if( password == null )password = "";
if( cmd == null ){
throw new Exception("cmd is not specified.");
}
com.trilead.ssh2.Connection conn = null;
Session sess = null;
String result = null;
try
{
// サーバに接続
conn = new com.trilead.ssh2.Connection(host);
conn.connect();
if( !conn.authenticateWithPassword(user, password) ){
throw new Exception("authentication failed.");
}
// コマンド実行
sess = conn.openSession();
sess.execCommand(cmd);
// 標準出力
BufferedReader stdout = new BufferedReader(
new InputStreamReader(
new StreamGobbler(sess.getStdout()), "UTF-8"));
StringBuffer sbuf = new StringBuffer();
String line = "";
while((line = stdout.readLine()) != null ){
sbuf.append(line);
sbuf.append("\n");
}
result = sbuf.toString();
}
finally
{
if( sess != null )sess.close();
if( conn != null )conn.close();
}
return result;
}
$$
実行例
select orionssh2_exec(
'192.168.1.25',
'user', 'password',
'ls -alF')
※以下のjarをCLASSPATH環境変数に追加
orion-ssh2-214.jar
○動作環境
JDK6 Update23, H2 Database 1.2.149 (2011-01-07)
○関連情報
・H2 Database上でOrion SSH2を使用するユーザー定義関数のまとめ
・H2 Databaseに関する他の記事はこちらを参照してください。
 
0 件のコメント:
コメントを投稿