2010年11月1日月曜日

H2 DatabaseとJCIFSでWindows共有上のファイルをコピーする関数を作成する

H2 DatabaseとJCIFSでWindows共有上のファイルをコピーする関数を作成するには、以下のスクリプトを実行します。

create alias if not exists jcifs_copy_file as $$ 
import java.io.*;
import java.sql.*;
import org.h2.tools.*;
import jcifs.smb.*;
@CODE
int jcifs_copy_file(String domain,
String user, String password, String server,
String path, String filename,
String path2, String filename2)
throws Exception
{
if( domain == null ){
throw new Exception("domain is not specified.");
}
user = (user == null)?"":user;
password = (password == null)?"":password;
if( server == null ){
throw new Exception("server is not specified.");
}
if( path == null ){
throw new Exception("path is not specified.");
}
if( filename == null ){
throw new Exception("filename is not specified.");
}
if( path2 == null ){
throw new Exception("path2 is not specified.");
}
if( filename2 == null ){
throw new Exception("filename2 is not specified.");
}

SmbFile src = new SmbFile(
"smb://" + domain + ";" + user + ":" + password +
"@" + server + "/" + path + "/" + filename
);
SmbFile dst = new SmbFile(
"smb://" + domain + ";" + user + ":" + password +
"@" + server + "/" + path2 + "/" + filename2
);
src.copyTo(dst);

return 0;
}
$$


実行例
call jcifs_copy_file(
'LIFERAY1',
'test1', 'test1', 'liferay1',
'share', 'SF.JPG',
'share', 'SF2.JPG');


※システム環境変数CLASSPATHにtools.jarとJCIFSのjar
(jcifs-1.3.15.jar)を追加しておくこと。

動作環境
JDK6 Update 21, H2 Database 1.2.143 (2010-09-18), JCIFS 1.3.15
○関連情報
・H2 Databaseに関する他の記事はこちらを参照してください。

0 件のコメント:

コメントを投稿