在这里我得先吐槽一下原本已经写好的博客。。结果手贱的点了本机导入,想要导入一下外部插件提供下载的。。结果直接把整篇博客给覆盖了。。真的是泪流满面啊。。但是为了各位的方便。也让我以后开发的时候有印象写过这东西。。我还是狠下心。再写一次
SpringMVC+AJAX+MultipartFile 异步上传图片在很多博客上基本上都有写,但是基本都是东缺一块西缺一块的,昨晚就调这东西调了很久,总算成功解决了。。
要用到ajaxfileupload.js这个插件,各位可以去网上下载
但这个插件貌似在jq1.2版本以上运行,就会开始报错,因为版本有点太老,各位调用的时候会发现他前端console报找不到handleError这个方法,在各位下载完ajaxfileupload之后,要记得把下面这段代码复制进里面,放在jQuery.extend({后面,别忘了最后那个逗号
handleError: function( s, xhr, status, e ) {
// If a local callback was specified, fire it
if ( 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] );
}
},
准备工作做完之后,别忘了这个js导入html的script标签的时候要放在jq的下面,否则调用不了,这是一些前端小白经常犯的问题。。然后接下来提供的是html部分的代码和ajax请求代码
由于ajaxfileupload调用的时候返回的是一个text类型的字段,所以千万不要设置dataType,否则会一直接收不到信息,下面已经用$.parseJSON处理了返回的对象成json了
function upPhoto(){
var url = "xxx";//这里填请求的地址
$.ajaxFileUpload({
url : url,
type : 'POST',
fileElementId : 'test1', //这里对应html中上传file的id
contentType:"application/json;charset=UTF-8",
success: function(data){
var str = $(data).find("body").text();//获取返回的字符串
var json = $.parseJSON(str);//把字符串转化为json对象
if(json.status){
alert("上传成功URL为" + json.url);
}
else{
alert("删除失败");
}
},
error: function(){
alert("请链接网络");
}
})
}
选择文件:<input type="file" name="file" id="test1">
<a onclick="upPhoto()">提交a>
这样子调用前台的准备工作基本上就完成了,接下里就是Springmvc中需要的东西,由于我用的mvc框架比较老,file的处理是封装写在service里的。所以Controller往里传的是单个的file,返回的是map对象
@Controller
@RequestMapping("/file")
public class FileController extends BaseController{
@ResponseBody
@RequestMapping(value="/upPhoto",method = RequestMethod.POST)
public Map processUpload(@RequestParam(value="file",required=false) MultipartFile file, HttpServletRequest request,HttpServletResponse response) {
Map map = new Files().processUploadPost(file);
return map;
}
}
下面是service里的代码
targPath是上传路径
isPhotoFormat是封装的判断文件格式是否正确的方法
generateFileName是一个根据时间来生成的名字,当有多个图片上传的时候会做特殊处理
logger是一个像日志那样打印情况的,不知道的可以百度一下
public Map<String, String> processUploadPost(MultipartFile file) {
Map<String, String> map = new HashMap<String,String>();
// 判断提交的请求是否包含文件
try {
// 上传文件的返回地址
String fileUrl = "";
if (file != null) {
//获取file的名字
String fileClientName = file.getOriginalFilename();
String fileSuffix = fileClientName.substring(fileClientName.lastIndexOf(".") - 1,fileClientName.length());
if (!isPhotoFormat(fileSuffix)) {
logger.error("上传文件的格式错误=" + fileSuffix);
map.put("status", "error");
map.put("message", "格式错误,仅支持jpg|jpeg|bmp|gif|png|txt|doc|docx|xls|xlsx|csv|ppt|pptx|pdf|wps|et|dps格式'");
return map;
}
if (logger.isInfoEnabled()) {
logger.info("开始上传文件:" + file.getName());
}
String fileServerName = generateFileName(file, fileSuffix);
// 为了客户端已经设置好了图片名称在服务器继续能够明确识别,这里不改名称
File tempFile = new File(targPath+"/"+fileServerName);
//文件转换
file.transferTo(tempFile);
if (logger.isInfoEnabled()) {
logger.info("上传文件结束,新名称:" + fileServerName + ".floder:"
+ tempFile.getPath());
}
// 组装返回url,以便于ckeditor定位图片
fileUrl = targPath+"/"+fileServerName;
map.put("status", "success");
map.put("message", "上传成功");
map.put("url", fileUrl);
System.out.println("成功");
}
else{
map.put("status", "error");
map.put("message", "文件为空");
}
} catch (IOException e) {
logger.error("上传文件发生异常!", e);
map.put("status", "error");
map.put("message", "上传文件发生异常!");
} catch (Exception e) {
logger.error("上传文件发生异常!", e);
map.put("status", "error");
map.put("message", "上传文件发生异常!");
}
return map;
}
private String generateFileName(MultipartFile folder, String suffix) {
String filename;
File file;
Date date = new Date(System.currentTimeMillis());
SimpleDateFormat format = new SimpleDateFormat("yyyyMMdd_HHmmss_SSS");
String base = format.format(date);
filename = base + "." + suffix;
file = new File(filename);
int i = 1;
while (file.exists()) {
filename = String.format("%s_%d.%s", base, i, suffix);
i++;
}
return filename;
}
public static Boolean isPhotoFormat(String fileSuffix){
if(StringUtils.equalsIgnoreCase(fileSuffix, "jpg")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "jpeg")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "bmp")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "gif")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "png")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "txt")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "doc")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "docx")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "xls")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "xlsx")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "csv")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "ppt")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "pptx")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "pdf")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "wps")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "et")
&& !StringUtils.equalsIgnoreCase(fileSuffix, "dps"))
return false;
return true;
}
以上的所有代码都完成以后,别忘了配置xml将这段xml代码扔进springmvc.xml即可,你的文件基本上就是上传成功的啦。
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="utf-8"/>
<property name="maxUploadSize" value="1000000"/>
<property name="uploadTempDir" value="/resource"/>
bean>
之前有发过不是关于项目的,而是关于acm算法的,基本上我是两个事情都有同时在做,感觉都是调试代码,编辑代码,设计代码,能锻炼的都是挺多的,只希望自己能在程序猿这条路上越走越远