1.以下のソースファイルをantなどでコンパイルします。
GetFtpBinaryFunction.java
package com.serverarekore.h2;
import java.io.*;
import java.sql.*;
import org.h2.tools.*;
import org.h2.value.*;
import org.apache.commons.net.ftp.*;
public class FtpGetBinaryFunction
{
static public InputStream ftp_get_binary(String host, Integer port,
String user, String password,
String path, String filename)
throws Exception
{
if( host == null ){
throw new Exception("host is not specified.");
}
int intPort = (port == null)?21:port.intValue();
user = (user == null)?"":user;
password = (password == null)?"":password;
path = (path == null)?".":path;
if( filename == null ){
throw new Exception("filename is not specified.");
}
InputStream ris = null;
FTPClient fc = new FTPClient();
try
{
// 接続
fc.connect(host, intPort);
if( !FTPReply.isPositiveCompletion(fc.getReplyCode()) ){
throw new Exception("failed to connect.");
}
// ログイン
if( fc.login(user, password) == false ){
throw new Exception("failed to login.");
}
// ファイル転送モードをasciiに
fc.setFileType(FTP.ASCII_FILE_TYPE);
// ファイルのダウンロード
InputStream is = fc.retrieveFileStream(filename);
final File tf = File.createTempFile("lobtmp", null);
FileOutputStream fos = new FileOutputStream(tf.getAbsolutePath());
byte buf[] = new byte[8192];
int rs = -1;
try
{
while( (rs = is.read(buf)) != -1 ){
fos.write(buf, 0, rs);
}
}
finally
{
fos.close();
is.close();
}
ris = new InputStream(){
private final InputStream fis = new FileInputStream(tf);
private boolean deleted = false;
private final File fn = tf;
public int autoDelete(int sz) throws IOException
{
if(sz < 0 ){
close();
}
return sz;
}
public void close() throws IOException
{
if( !deleted ){
fis.close();
fn.delete();
deleted = true;
}
}
public int read(byte buf[], int off, int len) throws IOException
{
return deleted?-1:autoDelete(fis.read(buf, off, len));
}
public int read(byte buf[]) throws IOException
{
return deleted?-1:autoDelete(fis.read(buf));
}
public int read() throws IOException
{
return deleted?-1:autoDelete(fis.read());
}
};
// ログアウト
fc.logout();
}
finally
{
if( fc.isConnected() ){
fc.disconnect();
}
}
return ris;
}
}
build.xmlのサンプル
<project name="H2Functions" default="compile" basedir=".">
<path id="lib.classpath">
<fileset dir="lib">
<include name="*.jar"/>
</fileset>
<pathelement location="c:/Program Files/H2/bin/h2.jar"/>
</path>
<target name="compile">
<echo message="project: ${ant.project.name}"/>
<mkdir dir="build/" />
<javac srcdir="src/" destdir="build/"
deprecation="on" debug="on">
<classpath>
<path refid="lib.classpath"/>
</classpath>
</javac>
<jar destfile="c:/share/jars/FtpGetBinary.jar"
basedir="build"/>
</target>
<target name="clean">
<delete dir="build" />
</target>
</project>
2.システム環境変数CLASSPATHにコンパイルしてできたFtpGetBinary.jarを追加し、
H2 Databaseのサービスを再起動。
3.H2 Consoleから以下のコマンドを実行して、ファンクション作成。
create alias ftp_get_binary for
"com.serverarekore.h2.FtpGetBinaryFunction.ftp_get_binary";
4.以下のようなコマンドでFTPサーバ上のファイルをBLOBに格納できます。
drop table if exists blobtest;
create table blobtest (c1 numeric(4), c2 blob);
insert into blobtest values (1,
ftp_get_binary('192.168.1.122', 21,
'ftptest1', 'ftptest1',
'.', 'SF.JPG')
);
※システム環境変数CLASSPATHにtools.jarとApache Commons Netのjar
(commons-net-2.0.jar, commons-net-ftp-2.0.jar)を追加しておくこと。
動作環境
JDK6 Update 21, H2 Database 1.2.143 (2010-09-18), Apache Commons Net 2.0
○関連情報
・H2 Databaseに関する他の記事はこちらを参照してください。
0 件のコメント:
コメントを投稿