成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

使用 ajaxFileUpload 進(jìn)行圖片上傳

newsning / 626人閱讀

摘要:前端部分使用主要是為了異步上傳文件,不需要開啟新的頁面進(jìn)行上傳由于不能上傳文件,該文件的代碼在本篇文章的最底部由于這個文件已經(jīng)很久沒用更新了,所以增加了來處理錯誤,前端代碼如下第一個中的屬性是為了限制上傳的文件屬性,其他文件可以去掉該屬性引

前端部分

使用ajaxFileUpload 主要是為了異步上傳文件,不需要開啟新的頁面進(jìn)行上傳!
由于segmentfault不能上傳文件,該文件ajaxFileUpload.js的代碼在本篇文章的最底部:
由于ajaxFileUpload這個文件已經(jīng)很久沒用更新了,所以增加了handleError: function( s, xhr, status, e )來處理錯誤,

前端代碼如下:
第一個input中的accept屬性是為了限制上傳的文件屬性,其他文件可以去掉該屬性

引用兩個js文件

 
 

上傳按鈕:


js代碼:

    //圖片上傳
    function ajaxFileUpload()
    {
         
        $.ajaxFileUpload({
                url:"/ai/app/uploadImage",//用于文件上傳的服務(wù)器端請求地址
                secureuri:false ,//一般設(shè)置為false
                fileElementId:"upload",//文件上傳控件的id屬性  
                dataType: "text",//返回值類型 一般設(shè)置為json
                success: function (message)  //服務(wù)器成功響應(yīng)處理函數(shù)
                {
                    layer.alert(message);
                    $("#tool_icon").val(message);
                },
                error: function (data, status, e)//服務(wù)器響應(yīng)失敗處理函數(shù)
                {
                    alert(e);
                }
            });
        return false;
    }
后端部分

該項目使用的spring框架,需要配置bean,來接受上傳的文件

  
      
          
    

后端代碼

@ResponseBody
    @RequestMapping(value="/uploadImage",method=RequestMethod.POST)
    public String uploadImage(HttpServletRequest request,@RequestParam("imagefile") MultipartFile file) throws IOException{
       String getOriginalFilename = null;
       logger.debug("文件原名: " + getOriginalFilename);
       logger.debug("文件名稱: " + file.getName());
       logger.debug("文件長度: " + file.getSize());
       logger.debug("文件類型: " + file.getContentType());
       if( file.isEmpty()){
          logger.error("upload image--------------------------------->failed");
          return "please select a image";
       }
       /**文件在服務(wù)器中的實際路徑*/
      
       String realPath = request.getSession().getServletContext().getRealPath("/upload");  
       logger.debug("realPath---------------------------------------->"+realPath);
       logger.debug("getOriginalFilename----------------------------->"+file.getOriginalFilename());
       
       /**寫入地址中*/
       FileUtils.copyInputStreamToFile(file.getInputStream(), new File(realPath,file.getOriginalFilename()));
       
       /**使用原生方法*/
       /* byte[] bytes = file.getBytes();
       BufferedOutputStream stream = new BufferedOutputStream(new FileOutputStream(new File("/ai/images/icons/toolLogo/demo.png")));
       stream.write(bytes);
       stream.close();*/
       /**返回文件在服務(wù)器中的地址,用于存儲入庫*/
       
       String resultUrl = "/ai/upload/"+file.getOriginalFilename();
       logger.debug("upload image file result----------------------->"+resultUrl);
       return resultUrl;
    }

相關(guān)jar包下載:org.apache.commons.io_1.3.2.jar org.apache.commons.fileupload.jar
相關(guān)jar包的地址
參考blog:
jQuery插件之a(chǎn)jaxFileUpload
http://blessht.iteye.com/blog/1405057
http://blog.csdn.net/jadyer/article/details/11693705
http://www.cnblogs.com/rollenholt/p/3693087.html

ajaxFileUpload.js 源代碼

// JavaScript Document
jQuery.extend({

    createUploadIframe: function(id, uri)
 {
   //create frame
            var frameId = "jUploadFrame" + id;
            
            if(window.ActiveXObject) {
                var io = document.createElement("