java ajax 上传文件_JavaWeb项目中使用ajax上传文件

1.jsp

$("#cxsc").click(function(){

var bankId = $("#bankId").val();

var formdata = new FormData();

formdata.append('logo', $('#btnFile').get(0).files[0]);

formdata.append('bankId', bankId);

$.ajax({

type: 'POST',

url: './uploadLogo',

contentType : false,

data : formdata,

processData : false,

dataType: "json",

success: function (data) {

$("#logoImg").attr('src','${_b}/upload/banklogo/'+data.msg);

},

error : function(data) {

alert('上传失败!');

}

});

%24%7BformData.logoImg%7D

上传

#if>

#if>

2.controller

@RequestMapping(value = "/uploadLogo", method = {RequestMethod.POST})

public void uploadLogo(

@RequestParam(value = "bankId", required = true) String bankId,

@RequestParam("logo") MultipartFile logo,

HttpServletRequest request, HttpServletResponse response, ModelMap model) {

Json json = new Json();

BankManage bankManage = bankManageService.getById(bankId);

if (bankManage != null) {

try {

if (!logo.isEmpty()) {

String relativePath = "/upload/banklogo";

// 旧图片路径

String absolutePath = request.getSession().getServletContext().getRealPath(relativePath)+"\\"+bankManage.getLogoImg();

File oldfile = new File(absolutePath);

if (oldfile.exists()) {

oldfile.delete(); // 删除旧图片

}

String newPath = request.getSession().getServletContext().getRealPath(relativePath)+"\\"+logo.getOriginalFilename();

File newFile = new File(newPath);

logo.transferTo(newFile);

bankManage.setLogoImg(logo.getOriginalFilename());

bankManageService.update(bankManage);

json.setMsg(logo.getOriginalFilename());

writeJson(request, response, json);

}else {

json.setMsg("上传失败!");

writeJson(request, response, json);

}

}catch (Exception e) {

e.printStackTrace();

logger.error(e);

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值