我正在使用spring MVC进行文件上传,它在firefox和chrome中工作正常,但在IE中显示无法上传..下面是我的jsp页面,其中包含fileuploader函数。
<div id="file-uploader-demo1" style="float: left;padding-top: 10px"></div>
</div>
<script>
function createUploader(){
var uploader = new qq.FileUploader ({
element: document.getElementById('file-uploader-demo1'),
action: '/Flas_ _/commu-____/insertFile;jsessionid=${sessionId}',
headers: {'Content-type':'multipart/form-data'},
multipleFileUpload: false,
debug: true
});
}
window.onload = createUploader;
</script>
这是我的jsp页面,其中iam包括FileUploader.js文件,action标记调用我各自的控制器,如下所示..
@RequestMapping(value = "/insertFile", method = RequestMethod.POST)
public String fileUpload(@RequestParam("qqfile") String filename1,ModelMap map,
HttpServletRequest request,HttpServletResponse response) throws IOException {
PrintWriter writer = null;
InputStream is = null;
FileOutputStream fos = null;
try {
writer = response.getWriter();
} catch (IOException ex) {
//log(OctetStreamReader.class.getName() + "has thrown an exception: " + ex.getMessage());
}
String filename = request.getHeader("X-File-Name");
this.setFILEUPLOAD(filename);
try {
is = request.getInputStream();
fos = new FileOutputStream(new File("F:/images/" + filename));
IOUtils.copy(is, fos);
response.setStatus(response.SC_OK);
writer.print("{success: true}");
} catch (FileNotFoundException ex) {
response.setStatus(response.SC_INTERNAL_SERVER_ERROR);
writer.print("{success: false}");
// log(OctetStreamReader.class.getName() + "has thrown an exception: " + ex.getMessage());
}catch (IOException ex) {
response.setStatus(response.SC_INTERNAL_SERVER_ERROR);
writer.print("{success: false}");
// log(OctetStreamReader.class.getName() + "has thrown an exception: " + ex.getMessage());
} finally {
try {
fos.close();
is.close();
} catch (IOException ignored) {
}
}
writer.flush();
writer.close();
return "do-nothing";
}
虽然在CHROME和FIREFOX中它的工作正常但我得到的文件存储在locale驱动器中。但它在IE 9中不起作用。我该怎么办?
dis的任何解决方案?请帮助谢谢。
答案 0 :(得分:0)
我通过实现两个控制器方法解决了另一个问题(在IE中工作,而不是在FF中工作)。我没有使用JavaScript上传器配置发送explizit标头。
一种方法(对于IE)具有额外的RequestMapping-Options:
headers = { "content-type=multipart/form-data" }
IE的RequestParam是MultipartFile
。从那里你将获得文件名和内容。 IE使用的正常分段上传的请求体不仅包含文件内容,而且还包含Firefox的ajax上传。它还具有多部分信息,如文件名和边界。 MultipartFile
可以为您处理此问题。
据我所知,必须进行一些常规设置才能启用webapp处理多部分文件上传。但这是另一个问题。