Kali ini kita akan membuat sebuah projek, dimana didalamnya ada fitur untuk mengupload sebuah document, document ini bisa berupa image ataupun format file lainya.
Pertama buat projek zk baru, jika anda belum tau caranya bisa lihat disini.
kedua pada index.zul isikan code seperti ini,
untuk lebih jelasnya hirarki projeknya seperti ini
berikut code indexcontroller.java
Selanjutnya pada zul.xml tambahkan script berikut
Pada bagian ini, kita mendefinisikan
1. file_size adalah Berapa max file yang diperbolehkan diupload,
2. save_path adalah direktori yang akan digunakan untuk penyimpanan file, jika direktori yang didefinisikan belum ada, maka secara otomatis system akan membuat foldernya di laptop/pc anda.
Pada bagian ini, kita mendefinisikan hal apa saja yang akan terjadi ketika menekan tombol upload.
didalamnya ada validasi file size, kemudia ada validasi apakah file yang kita upload image atau bukan, kalau image maka akan ditampilkan di index.zul. di bagian ini juga kita memanggil fungsi simpan file.
Pada bagian ini sistem kan menyimpan file yang kita upload.
Cukup sekian blog saya kali ini, anda bisa mendownload projek ini di github saya disini.
Apabila ada yang ingin ditanyakan silahkan komen dibawah, jika anda ingin respon yang cepat dari saya, anda bisa kirim email ke firdausofyusuf@gmail.com
Terimakasih.
Pertama buat projek zk baru, jika anda belum tau caranya bisa lihat disini.
kedua pada index.zul isikan code seperti ini,
<?xml version="1.0" encoding="UTF-8"?>
<zk xmlns="http://www.zkoss.org/2005/zul">
<window title="Contoh Upload File ZK" apply="controller.indexComposer">
<button id="uploadBtn" label="Upload file" />
<separator />
<image width ="300px" height="300px" id="img" />
<separator />
<label id="msgLb" />
</window>
</zk>
Ketiga buat file controllernya yaitu file indexController.java, sebelumnya buat sebuah folder bernama "controller" di /src/java/<zk xmlns="http://www.zkoss.org/2005/zul">
<window title="Contoh Upload File ZK" apply="controller.indexComposer">
<button id="uploadBtn" label="Upload file" />
<separator />
<image width ="300px" height="300px" id="img" />
<separator />
<label id="msgLb" />
</window>
</zk>
untuk lebih jelasnya hirarki projeknya seperti ini
Hirarki projek |
berikut code indexcontroller.java
package controller;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.zkoss.util.media.Media;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.util.GenericForwardComposer;
import org.zkoss.zul.*;
/**
*
* @author yusuf
*/
public class indexComposer extends GenericForwardComposer {
private Image img;
private Label msgLb;
private static final int FILE_SIZE = 1000;// 100k
private static final String xdate = new SimpleDateFormat("yyyy-MM-dd").format(new Date());
private static final String SAVE_PATH = "/home/yusuf/Documents/upload/" + xdate + "/";
// private static final String SAVE_PATH = "c:\\myfile\\media\\" + xdate + "/"; //ganti jika windows
@Override
public void doAfterCompose(Component comp) throws Exception {
super.doAfterCompose(comp);
}
public void onClick$uploadBtn() {
msgLb.setValue("");
Media media = Fileupload.get();
if (media == null) {
msgLb.setValue("please select a file");
return;
}
String type = media.getContentType().split("/")[0];
if (type.equals("image")) {
if (media.getByteData().length > FILE_SIZE * 1024) {
msgLb.setValue("File size limit " + FILE_SIZE + "k");
return;
}
org.zkoss.image.Image picture = (org.zkoss.image.Image) media;
img.setContent(picture);
}
saveFile(media);
}
private void saveFile(Media media) {
BufferedInputStream in = null;
BufferedOutputStream out = null;
try {
InputStream fin = media.getStreamData();
in = new BufferedInputStream(fin);
File baseDir = new File(SAVE_PATH);
if (!baseDir.exists()) {
baseDir.mkdirs();
}
File file = new File(SAVE_PATH + media.getName());
OutputStream fout = new FileOutputStream(file);
out = new BufferedOutputStream(fout);
byte buffer[] = new byte[1024];
int ch = in.read(buffer);
while (ch != -1) {
out.write(buffer, 0, ch);
ch = in.read(buffer);
}
msgLb.setValue("sucessed upload :" + media.getName());
} catch (IOException e) {
throw new RuntimeException(e);
} catch (Exception e) {
throw new RuntimeException(e);
} finally {
try {
if (out != null) {
out.close();
}
if (in != null) {
in.close();
}
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
}
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.zkoss.util.media.Media;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.util.GenericForwardComposer;
import org.zkoss.zul.*;
/**
*
* @author yusuf
*/
public class indexComposer extends GenericForwardComposer {
private Image img;
private Label msgLb;
private static final int FILE_SIZE = 1000;// 100k
private static final String xdate = new SimpleDateFormat("yyyy-MM-dd").format(new Date());
private static final String SAVE_PATH = "/home/yusuf/Documents/upload/" + xdate + "/";
// private static final String SAVE_PATH = "c:\\myfile\\media\\" + xdate + "/"; //ganti jika windows
@Override
public void doAfterCompose(Component comp) throws Exception {
super.doAfterCompose(comp);
}
public void onClick$uploadBtn() {
msgLb.setValue("");
Media media = Fileupload.get();
if (media == null) {
msgLb.setValue("please select a file");
return;
}
String type = media.getContentType().split("/")[0];
if (type.equals("image")) {
if (media.getByteData().length > FILE_SIZE * 1024) {
msgLb.setValue("File size limit " + FILE_SIZE + "k");
return;
}
org.zkoss.image.Image picture = (org.zkoss.image.Image) media;
img.setContent(picture);
}
saveFile(media);
}
private void saveFile(Media media) {
BufferedInputStream in = null;
BufferedOutputStream out = null;
try {
InputStream fin = media.getStreamData();
in = new BufferedInputStream(fin);
File baseDir = new File(SAVE_PATH);
if (!baseDir.exists()) {
baseDir.mkdirs();
}
File file = new File(SAVE_PATH + media.getName());
OutputStream fout = new FileOutputStream(file);
out = new BufferedOutputStream(fout);
byte buffer[] = new byte[1024];
int ch = in.read(buffer);
while (ch != -1) {
out.write(buffer, 0, ch);
ch = in.read(buffer);
}
msgLb.setValue("sucessed upload :" + media.getName());
} catch (IOException e) {
throw new RuntimeException(e);
} catch (Exception e) {
throw new RuntimeException(e);
} finally {
try {
if (out != null) {
out.close();
}
if (in != null) {
in.close();
}
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
}
Selanjutnya pada zul.xml tambahkan script berikut
<system-config>
<ui-factory-class>org.zkoss.zk.ui.http.SerializableUiFactory</ui-factory-class>
</system-config>
Penjelasan<ui-factory-class>org.zkoss.zk.ui.http.SerializableUiFactory</ui-factory-class>
</system-config>
upload file menggukanak zkoss |
Pada bagian ini, kita mendefinisikan
1. file_size adalah Berapa max file yang diperbolehkan diupload,
2. save_path adalah direktori yang akan digunakan untuk penyimpanan file, jika direktori yang didefinisikan belum ada, maka secara otomatis system akan membuat foldernya di laptop/pc anda.
upload file menggukanak zkoss |
Pada bagian ini, kita mendefinisikan hal apa saja yang akan terjadi ketika menekan tombol upload.
didalamnya ada validasi file size, kemudia ada validasi apakah file yang kita upload image atau bukan, kalau image maka akan ditampilkan di index.zul. di bagian ini juga kita memanggil fungsi simpan file.
upload file menggukanak zkoss |
Pada bagian ini sistem kan menyimpan file yang kita upload.
Cukup sekian blog saya kali ini, anda bisa mendownload projek ini di github saya disini.
Apabila ada yang ingin ditanyakan silahkan komen dibawah, jika anda ingin respon yang cepat dari saya, anda bisa kirim email ke firdausofyusuf@gmail.com
Terimakasih.
selamat siang, contoh di atas itu jika kita ingin menyimpan pada komputer ya mas ? bisakah saya meminta source code jika kita ingin menyimpan gambar/file hasil upload tsb ke database. di sini saya ingin mengunakan database oracle. terima kasih
BalasHapusSiang arka, saya sendiri lebih prefer untuk "tidak" menyimpan file k dalam database, karena itu akan menyebabkan database menjadi lebih cepat gemuk, jadi untuk source codenya sayang sekali saya tidak punya,
Hapusttapi jika kamu ingin tetap melakukanya, kamu bisa membuat column baru lalu memilih type data blob, kemudian file yang kamu ingin buat di ubah kedalam bentuk binary, baru km insert ke column blob tadi.
baik. terima kasih atas sarannya akan saya coba
Hapus