本文实现的功能主要是将文件上传到后台,然后后台可以方便的处理文件。
我要使用到的文件主要就是ajaxfileupload.js+jquery-1.12.0.js,其中的网上下载的ajaxfileupload.js里边一般会报错handlerError,
加上这个就好了:handleError: function( s, xhr, status, e ) {
// If a local callback was specified, fire itif ( s.error ) {
s.error.call( s.context || s, xhr, status, e );
}
// Fire the global callback
if ( s.global ) {
(s.context ? jQuery(s.context) : jQuery.event).trigger( "ajaxError", [xhr, s, e] );
}
}
jsp的选择文件框要给<input name="uploadFile" id="uploadFile" type="file" size="50">,其中的name和id一定要设置好,后边会用到
js里边加上如下的:
$.ajaxFileUpload({
url:"sb.do?action=pldrSubmit",//请求路径
fileElementId:'uploadFile',//需要上传的文件域id即<input name="uploadFile" id="uploadFile" type="file" size="50">
dataType : "TEXT", //这里的text要大写否则经常会报一个错误
success: function(result){
var dao = result.toString().toLowerCase();
var mstart = dao.indexOf("<retmsg>");
var mend = dao.indexOf("</retmsg>");
var retmsg = dao.substring(mstart+8,mend);
if(null==retmsg || ""==retmsg || "null"==retmsg){
var tstart = dao.indexOf("<type>");
var tend = dao.indexOf("</type>");
var type = dao.substring(tstart+6,tend);
if(100==type){
alert("接收成功!");
}else{
alert(retmsg);
}
}else{
alert(retmsg);
}
return;
},}
);
action里边如下:
@RequestMapping(params = "action=pldrSubmit")
public void pldrSubmit(@RequestParam("uploadFile") MultipartFile uploadFile, HttpServletRequest request,HttpServletResponse response){
log.debug("file name is :" + uploadFile.getOriginalFilename());
String excute = null;
if (!uploadFile.isEmpty()) {
try {
byte[] bytes = uploadFile.getBytes();//传过来,返回一个按位的数组
String sxml = new String(bytes,"GBK");//将传过来的文件转成字符串
log.info("---批量导入--"+sxml);
String requestXml = "<Record><fileName>"+uploadFile.getOriginalFilename()+"</fileName><byteArray>"+sxml+"</byteArray></Record>";
excute = service.excute("hgjk_pldlService",requestXml);
log.debug(excute);
} catch (IOException e) {
e.printStackTrace();
}
// String excute = "<type>100</type>";
try {
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html; charset=UTF-8");
response.getWriter().print(excute);
} catch (IOException e) {
e.printStackTrace();
}
}
}
这里的MultipartFile这个接口主要的方法有:
public abstract java.lang.String getName();//Return the name of the parameter in the multipart form.
public abstract java.lang.String getOriginalFilename();//Return the original filename in the client's filesystem.
public abstract java.lang.String getContentType(); //Return the content type of the file.
public abstract boolean isEmpty();//Return whether the uploaded file is empty, that is, either no file hasbeen chosen in the multipart form or the chosen file has no content.
public abstract long getSize(); //Return the size of the file in bytes.
public abstract byte[] getBytes() throws java.io.IOException; //Return the contents of the file as an array of bytes.
public abstract java.io.InputStream getInputStream() throws java.io.IOException; //Return an InputStream to read the contents of the file from.
public abstract void transferTo(java.io.File arg0) throws java.io.IOException, java.lang.IllegalStateException;//Transfer the received file to the given destination file.
在springMVC中配置如下:
<!-- 上传文件拦截,设置最大上传文件大小 100M=100*1024*1024(B)=10485760 bytes -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="104857600" />
</bean>