Spring MVC中 ajaxfileupload实现ajax上传文件

页面代码:

<html>
    <!-- 引入相关的js文件,相对路径  -->
    <script type="text/javascript" src="js/jquery.js"></script>
      <script type="text/javascript" src="js/ajaxfileupload.js"></script>

    <!-- 执行上传文件操作的函数 -->
      <script type="text/javascript">
          function ajaxFileUpload(){
               $.ajaxFileUpload(
                   {
                url:'update.do?method=uploader',            //需要链接到服务器地址
                secureuri:false,
                fileElementId:'houseMaps',                        //文件选择框的id属性
                dataType: 'json',                                     //服务器返回的格式,可以是json, xml
                success: function (data, status)            //相当于java中try语句块的用法
                {      
                    $('#result').html('添加成功');
                },
                error: function (data, status, e)            //相当于java中catch语句块的用法
                {
                    $('#result').html('添加失败');
                }
            }
                   
               );
              
          }
      </script>
  </head>
  
  <body>
      <div>  
        <input type="file" id="houseMaps" name="houseMaps"/> 
        <input type="button" value="提交" οnclick="ajaxFileUpload()"/>
    </div> 
    <div id="result"></div>
    
  </body>
</html>

java代码 :

 

@RequestMapping(method=RequestMethod.POST, value="/imgupload")

public @ResponseBody String uploadImg(HttpServletRequest request, @RequestParam("imgFile") MultipartFile imgFile){

String uploadDir = request.getRealPath("/upload");  

        File dirPath = new File(uploadDir);  

        if (!dirPath.exists()) {  

            dirPath.mkdirs();  

        }

        String uuid = UuidUtil.getUUID();

String oriName = imgFile.getOriginalFilename();

//文件名后缀处理---start---

String _suffix = oriName.substring(oriName.lastIndexOf(".")+1, oriName.length());

//-----end---

//---重新处理文件名start---

String suffix = oriName.substring(oriName.lastIndexOf("."), oriName.length());

String newFileName = uuid + suffix;

        try {

imgFile.transferTo(new File(uploadDir + "/" + newFileName));

} catch (IllegalStateException e) {

// TODO Auto-generated catch block

e.printStackTrace();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

        //---end---

        File file = new File(uploadDir + "/" + newFileName);

        String fileUrl = FtpUtil.ftp2NFS(file, "image", newFileName, "test", "image", "42");

        dirPath.delete();

        JSONObject object = new JSONObject();

        if("error".equals(fileUrl)){

        object.put("success", "false");

        }else{

        object.put("success", "true");

        object.put("filePath", PropUtil.getImagePath() + fileUrl);

        }

return JSONObject.fromObject(object).toString();

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值