问题描述
好的,所以我让上传器使用 Java FTP 上传文件,我想更新标签和进度条.带有百分比文本的标签,带有百分比 int 值的栏.现在使用当前代码只能在上传结束时获得 100 和完整栏.在上传过程中,它们都没有改变.
OK so I have the uploader uploading files using the Java FTP, I would like to update the label and the progress bar. Label with the percent text, bar with the percent int value. Right now with the current code only get the 100 and full bar at the end of the upload. During the upload none of them change.
这里是:
OutputStream output = new BufferedOutputStream(ftpOut);
CopyStreamListener listener = new CopyStreamListener() {
public void bytesTransferred(long totalBytesTransferred, int bytesTransferred, long streamSize) {
System.out.printf("\r%-30S: %d / %d", "Sent", totalBytesTransferred, streamSize);
ftpup.this.upd(totalBytesTransferred,streamSize);
}
public void bytesTransferred(CopyStreamEvent arg0) { }
};
Util.copyStream(input, output, ftp.getBufferSize(), f.length(), listener);
}
public void upd(long num, long size){
int k = (int) ((num*100)/size);
System.out.println(String.valueOf(k));
this.d.setText(String.valueOf(k));
//d.setText(String.valueOf(k));
progressBar.setValue(k);
}
推荐答案
从它的声音(并且缺乏对contree 的任何证据)这听起来像是您在事件调度线程
From the sounds of it (and lacking any evidence to the contree) it sounds like your processing a time consuming action in the Event Dispatching Thread
您可能想阅读Swing 中的并发进一步洞察
You might like to read Concurrency in Swing for some further insight
我建议使用 SwingWorker 来执行实际转移利用其内置的进度支持
I'd suggest using a SwingWorker to perform the actual transfer & take advantage of its built in progress support
看到源代码后更新
- 不要将重量级组件与重量级组件混合使用.将
Applet
改为JApplet
,将TextField
改为JTextField
,不要使用Canvas
使用JPanel
或JComponent
- 如果您希望其他人阅读您的代码,请为您的变量使用适当的名称,我不知道
p
是什么. - 你的
Thread
没用.而不是启动线程并使用它的run
方法,您只需在它的构造函数中进行下载调用.这对你无济于事...
- Don't mix heavy weight components with light weight components. Change
Applet
toJApplet
, changeTextField
toJTextField
, don't useCanvas
use aJPanel
orJComponent
- If you expect other people to read your code, please use proper names for your variables, I have no idea what
p
is. - Your
Thread
is useless. Rather then starting the thread and using it'srun
method you simply make your download call within it's constructor. This will do nothing for you...
删除您的 MyThread
实现并将其替换为
Remove your implementation of MyThread
and replace it with
public class MyWorker extends SwingWorker<Object, Object> {
private URL host;
private File outputFile;
public MyWorker(URL host, File f) {
this.host = host;
outputFile = f;
}
@Override
protected Object doInBackground() throws Exception {
// You're ignoring the host you past in to the constructor
String hostName = "localhost";
String username = "un";
String password = "pass";
String location = f.toString();
//FTPClient ftp = null;
ftp.connect(hostName, 2121);
ftp.login(username, password);
ftp.setFileType(FTP.BINARY_FILE_TYPE);
ftp.setKeepAlive(true);
ftp.setControlKeepAliveTimeout(3000);
ftp.setDataTimeout(3000); // 100 minutes
ftp.setConnectTimeout(3000); // 100 minutes
ftp.changeWorkingDirectory("/SSL");
int reply = ftp.getReplyCode();
System.out.println("Received Reply from FTP Connection:" + reply);
if (FTPReply.isPositiveCompletion(reply)) {
System.out.println("Connected Success");
}
System.out.println(f.getName().toString());
File f1 = new File(location);
in = new FileInputStream(f1);
FileInputStream input = new FileInputStream(f1);
// ftp.storeFile(f.getName().toString(),in);
//ProgressMonitorInputStream is= new ProgressMonitorInputStream(getParent(), "st", in);
OutputStream ftpOut = ftp.storeFileStream(f.getName().toString());
System.out.println(ftpOut.toString());
//newname hereSystem.out.println(ftp.remoteRetrieve(f.toString()));
OutputStream output = new BufferedOutputStream(ftpOut);
CopyStreamListener listener = new CopyStreamListener() {
public void bytesTransferred(final long totalBytesTransferred, final int bytesTransferred, final long streamSize) {
setProgress((int) Math.round(((double) totalBytesTransferred / (double) streamSize) * 100d));
}
@Override
public void bytesTransferred(CopyStreamEvent arg0) {
// TODO Auto-generated method stub
}
};
Util.copyStream(input, output, ftp.getBufferSize(), f.length(), listener);
return null;
}
}
在您的 o
(??) 的 ActionListener
中,将线程执行代码替换为
In your ActionListener
of o
(??) replace the thread execution code with
try {
MyWorker worker = new MyWorker(new URL("http://localhost"), file);
worker.addPropertyChangeListener(new PropertyChangeListener() {
@Override
public void propertyChange(PropertyChangeEvent evt) {
if (evt.getPropertyName().equals("progress")) {
Integer progress = (Integer) evt.getNewValue();
progressBar.setValue(progress);
}
}
});
worker.execute();
} catch (MalformedURLException ex) {
ex.printStackTrace();
}
注意.您忽略了传递给构造函数的 URL.http://不是 ftp://所以我怀疑这会起作用...
Note. You are ignoring the URL you pass to the constructor. http:// is not ftp:// so I doubt this will work...
这篇关于在 Java 小程序中显示 FTP 文件上传过程中的进度的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!