Java使用Ajax异步上传文件

网友投稿 251 2023-01-12

Java使用Ajax异步上传文件

相关代码示例:

html代码片段:

class="layui-input">

请选择配置文件

js代码片段:

//上传配置文件

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

var name = $("#config_name").val();

var desc = $("#config_desc").val();

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

var formData = new FormData($("#uploadForm")[0]);

formData.append("name",name);

formData.append("desc",desc);

formData.append("userId",userId);

$.ajax({

url: 'http://localhost:8090/bfi-web/api/ide/settings/uploadFiles',

type: 'POST',

data: formData,

async: false,

cache: false,

contentType: false,

processData: false,

success: function (returndata) {

layui.use('layer', function () {

var layer = layui.layer;

layer.msg(returndata.returnMsg, {

icon: 1

});

});

setTimeout(() => {

closeLayui();

}, 300);

},

error: function (returndata) {

console.log("====================Error==========================");

}

});

});

java代码片段(这里是SpringMVC+腾讯云对象存储,可将其更换为其它对象存储,如七牛云、ftp或者是其它对象存储):

/**

* 上传文件

* @param request

* @param file

* @return

*/

@PostMapping(value="/uploadFiles",produces="application/json;charset=utf-8")

public JSONObject upModify(HttpServletRequest request, MultipartFile file) {

JSONObject json = new JSONObject();

try {

COSClientUtil cosClientUtil = new COSClientUtil();

if(!file.isEmpty()) {

String name = cosClientUtil.uploadFile2Cos(file);

String desc = request.getParameter("desc");

String names = request.getParameter("name");

String userId = request.getParameter("userId");

logger.info("desc:"+desc);

logger.info("names:"+names);

logger.info("userId:"+userId);

//图片名称

logger.info("name = " + name);

//上传到腾讯云

String imgUrl = cosClientUtil.getImgUrl(name);

logger.info("imgUrl = " + imgUrl);

//数据库保存图片地址

String dbImgUrl = imgUrl.substring(0,imgUrl.indexOf("?"));

logger.info("dbImgUrl = " + dbImgUrl);

IdeSettings ide = new IdeSettings();

ide.setName(names);

ide.setContent(dbImgUrl);

ide.setUserId(userId);

ide.setUpdateTime(DateUtil.date().toString());

ide.setUploadTime(DateUtil.date().toString());

ide.setDescription(desc);

boolean isAddConfig = ideSettingsService.insert(ide);

logger.info(isAddConfig);

if(isAddConfig) {

json.put(CommonEnum.RETURN_CODE, "000000");

json.put(CommonEnum.RETURN_MSG, "上传成功");

}else {

json.put(CommonEnum.RETURN_CODE, "222222");

json.put(CommonEnum.RETURN_MSG, "上传失败");

}

}else {

json.put(CommonEnum.RETURN_CODE, "111111");

json.put(CommonEnum.RETURN_MSG, "参数异常");

}

} catch (Exception e) {

e.printStackTrace();

json.put(CommonEnum.RETURN_CODE, "333333");

json.put(CommonEnum.RETURN_MSG, "特殊异常");

}

return json;

}

另一种示例:

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('上传失败!');

                    }

                });

 

<#if formData?exists>

                            <#if (formData.logoImg??)>

                                

                                

                                

                                

                            <#else>

                                

                            #if>

                        <#else>

                            

                        #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);

            }

        }

    }

以上就是Java使用Ajax异步上传文件的详细内容,更多关于Java 用Ajax上传文件的资料请关注我们其它相关文章!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:德邦快递物流查询单号查询(德邦快递快递查询单号查询)
下一篇:众佳物流查询(众鑫物流单号查询方式)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~