我正在尝试使用Axis2 Web服务上传1024个块大小的文件。
我的服务器端看起来像这样:
public void appendChunk(int count, byte[] buffer){
FileOutputStream fos = null;
try {
File destinationFile = new File("c:\\file1.exe");
fos = new FileOutputStream(destinationFile,true);
fos.write(buffer,0, count);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
finally{
try {
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
我的客户端看起来像这样:
static int CHUNK_SIZE =1024;
public static void main(String[] args) throws IOException, ServiceException {
FileUploadService strub = new FileUploadServiceLocator();
FileUploadServicePortType a = strub.getFileUploadServiceHttpSoap12Endpoint();
byte[] buffer = new byte[CHUNK_SIZE];
FileInputStream fis = null;
File file = new File("C:\\install.exe");
int count;
try {
fis = new FileInputStream(file);
while((count = fis.read(buffer, 0, CHUNK_SIZE)) >0 )
{
a.appendChunk(count, buffer);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
}
finally{
fis.close();
}
}
之后文件大小不正确,如果原始文件大小为500 Kb,原始大小在200到400k之间变化。
我做错了什么?
更新:我查看了Tomcat中的log4j文件
Nov 17, 2010 2:08:31 PM org.apache.tomcat.util.net.JIoEndpoint createWorkerThread
INFO: Maximum number of threads (200) created for connector with address null and port 80
看起来所有对Web服务器的请求都是异步完成的,并且我也得到IO异常,该文件被另一个进程使用。
答案 0 :(得分:1)
尝试在服务器实施中的fos.flush();
之前添加fos.close();
。
更改
while((count = fis.read(buffer, 0, CHUNK_SIZE)) >0 )
的
while((count = fis.read(buffer, 0, CHUNK_SIZE)) != -1 )