搜索
首页Javajava教程用ajaxfileupload实现无刷新上传的代码示例

用ajaxfileupload实现无刷新上传的代码示例

May 05, 2017 pm 02:45 PM
ajaxfileupload

本篇文章主要介绍了SpringMVC结合ajaxfileupload实现文件无刷新上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

jQuery没有提供ajax的文件上传,我们可以通过ajaxfileupload实现ajax文件的上传。其实ajaxfileupload文件上传特别的简单。下面就演示一下在SpringMVC中实现ajax的文件上传。

1、后台接收代码

首先在spring的配置文件中添加文件上传配置  

<!-- 文件上传 -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="UTF-8"/> 
</bean>

再写文件接收的代码

package com.chinaunicom.jlmssp.controller;

import java.io.File;
import java.io.IOException;
import java.util.Arrays;
import java.util.Date;
import java.util.HashMap;

import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.apache.commons.fileupload.servlet.ServletFileUpload;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

import com.chinaunicom.jlmssp.model.DataResponse;
import com.chinaunicom.jlmssp.model.JavaToJsMsg;
import com.chinaunicom.jlmssp.model.Org_UserInfo;
import com.chinaunicom.jlmssp.model.Repaly_Expert_Home_Page;
import com.chinaunicom.jlmssp.services.Replay_ExpertManageService;

/**
 * 项目复制管理子系统
 * 专家云管理
 * @author SunYue
 * @version 0.1
 */
@Controller
@RequestMapping("/admin/Replay_ExpertManageController.do")
public class Replay_ExpertManageController {
  
  private static final HashMap<String, String> TypeMap = new HashMap<String, String>();

  static {
    TypeMap.put("image", "gif,jpg,jpeg,png,bmp");
    TypeMap.put("flash", "swf,flv");
    TypeMap.put("media", "swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb");
    TypeMap.put("file", "doc,docx,xls,xlsx,ppt,pptx,htm,html,txt,dwg,pdf");
  }


  @Autowired
  Replay_ExpertManageService replayExpertManageService;
    
    /**
     * @author sunyue
     * @date 2017年2月28日 下午12:49:33
     * @Description: 图片上传方法
     * @return message: -1 没有文件上传 0 上传成功 1 上传失败 2 文件超过上传大小 3 文件格式错误 4 上传文件路径非法 5 上传目录没有写权限
     * @return void 返回类型
     */
    @RequestMapping(params = "op=getImageUpload", method = RequestMethod.POST)
    public void getImageUpload(@RequestParam("upload") CommonsMultipartFile file,HttpServletRequest request,
        HttpServletResponse response) {
      if (!file.isEmpty()) {
        /*ServletContext servletContext = request.getSession()
            .getServletContext();
        String uploadPath = servletContext.getRealPath("/")
            + "images\\replay-expert\\";
        
        String upPathString = request.getServletPath(); */
        
        //获取项目工作空间下工程路径的方法,将图片保存到工程路径下
        String t=Thread.currentThread().getContextClassLoader().getResource("").getPath();
         int num=t.indexOf(".metadata");
         String uploadPath=t.substring(1,num).replace(&#39;/&#39;, &#39;\\&#39;)+"jl_mssp_V3_0\\WebContent\\images\\replay-expert\\";
        
        // 文件上传大小
        long fileSize = 3 * 1024 * 1024;

        if (file.getSize() > fileSize) {
          backInfo(response, false, 2, "");
          return;
        }

        String OriginalFilename = file.getOriginalFilename();

        String fileSuffix = OriginalFilename.substring(
            OriginalFilename.lastIndexOf(".") + 1).toLowerCase();
        if (!Arrays.asList(TypeMap.get("image").split(",")).contains(
            fileSuffix)) {
          backInfo(response, false, 3, "");
          return;
        }

        if (!ServletFileUpload.isMultipartContent(request)) {
          backInfo(response, false, -1, "");
          return;
        }

        // 检查上传文件的目录
        File uploadDir = new File(uploadPath);
        if (!uploadDir.isDirectory()) {
          if (!uploadDir.mkdir()) {
            backInfo(response, false, 4, "");
            return;
          }
        }

        // 是否有上传的权限
        if (!uploadDir.canWrite()) {
          backInfo(response, false, 5, "");
          return;
        }
        
        //新文件名
        String newname = "";
        /*if(null != filePre){
          newname += filePre;//对应模块上传的文件名前缀
        }*/
        
         newname +=  "test1111" + "." + fileSuffix;

        File saveFile = new File(uploadPath, newname);

        try {
          file.transferTo(saveFile);
          backInfo(response, true, 0, newname);
        } catch (Exception e) {
          //LOG.error(e.getMessage(), e);
          backInfo(response, false, 1, "");
          return;
        }
      } else {
        backInfo(response, false, -1, "");
        return;
      }
    }
    
    // 返回信息
    private void backInfo(HttpServletResponse response, boolean flag, int message,
        String fileName) {
      String json = "";
      if (flag) {
        json = "{ \"status\": \"success";
      } else {
        json = "{ \"status\": \"error";
      }
      json += "\",\"fileName\": \"" + fileName + "\",\"message\": \"" + message + "\"}";
      try {
        response.setContentType("text/html;charset=utf-8");
        response.getWriter().write(json);
      } catch (IOException e) {
        //LOG.error(e.getMessage(), e);
      }
    }
}

2、前台接受代码

使用ajaxfileupload时,首先下载ajaxfileupload文件,导入对应的js文件   

<script type="text/javascript" src="js/ajaxfileupload.js"></script>

文件传输字段必须为file类型,如下:

<input type="file" id="file" name="file" onchange="ajaxFileUpload();"/>

 其次,处理上传文件: 

function ajaxFileUpload() {
  $.ajaxFileUpload({
    type: "POST",
    async: false,
    data: { "op": &#39;getImageUpload&#39;},
    url:"Replay_ExpertManageController.do",
    dataType: &#39;json&#39;,
    secureuri: false,
    fileElementId: "upload",
    success: function(data, status) {
      if (data.status == "success") {
        //上传成功
        alert("上传照片成功");
      }
      switch(data.message){
       //解析上传状态
        case "0" : //上传成功
              break;
        case "-1" : //上传文件不能为空
             break;
        default: //上传失败
           break;
      }
      return false;
    }/* ,
    error : function (jqXHR, textStatus, errorThrown) {
      //弹出jqXHR对象的信息
      alert(jqXHR.responseText);
      //alert(jqXHR.status);
      //alert(jqXHR.readyState);
      //alert(jqXHR.statusText);
        //弹出其他两个参数的信息
      //alert(textStatus);
      alert(errorThrown);
      return false;
    } */
  });
}

三、由于网上的ajaxuploadfile文件都是高版本的,这里将改版完全版文件传上,自己使用

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] );
        }
  },
  createUploadIframe: function(id, uri)
  {
 
    var frameId = &#39;jUploadFrame&#39; + id;
    
    if(window.ActiveXObject) {
      if(jQuery.browser.version=="9.0")
      {
        io = document.createElement(&#39;iframe&#39;);
        io.id = frameId;
        io.name = frameId;
      }
      else if(jQuery.browser.version=="6.0" || jQuery.browser.version=="7.0" || jQuery.browser.version=="8.0")
      {
      
        var io = document.createElement(&#39;<iframe id="&#39; + frameId + &#39;" name="&#39; + frameId + &#39;" />&#39;);
        if(typeof uri== &#39;boolean&#39;){
          io.src = &#39;javascript:false&#39;;
        }
        else if(typeof uri== &#39;string&#39;){
          io.src = uri;
        }
      }
    }
    else {
      var io = document.createElement(&#39;iframe&#39;);
      io.id = frameId;
      io.name = frameId;
    }
    io.style.position = &#39;absolute&#39;;
    io.style.top = &#39;-1000px&#39;;
    io.style.left = &#39;-1000px&#39;;

    document.body.appendChild(io);

    return io;    
  },
  ajaxUpload:function(s,xml){
    //if((fromFiles.nodeType&&!((fileList=fromFiles.files)&&fileList[0].name)))

    var uid = new Date().getTime(),idIO=&#39;jUploadFrame&#39;+uid,_this=this;
    var jIO=$(&#39;<iframe name="&#39;+idIO+&#39;" id="&#39;+idIO+&#39;" style="display:none">&#39;).appendTo(&#39;body&#39;);
    var jForm=$(&#39;<form action="&#39;+s.url+&#39;" target="&#39;+idIO+&#39;" method="post" enctype="multipart/form-data"></form>&#39;).appendTo(&#39;body&#39;);
    var oldElement = $(&#39;#&#39;+s.fileElementId);
    var newElement = $(oldElement).clone();
    $(oldElement).attr(&#39;id&#39;, &#39;jUploadFile&#39;+uid);
    $(oldElement).before(newElement);
    $(oldElement).appendTo(jForm);

    this.remove=function()
    {
      if(_this!==null)
      {
        jNewFile.before(jOldFile).remove();
        jIO.remove();jForm.remove();
        _this=null;
      }
    }
    this.onLoad=function(){
    
      var data=$(jIO[0].contentWindow.document.body).text();
  
  
      try{

        if(data!=undefined){
          data = eval(&#39;(&#39; + data + &#39;)&#39;);
          try {
            
            if (s.success)
              s.success(data, status);
  
            // Fire the global callback
            if(s.global)
              jQuery.event.trigger("ajaxSuccess", [xml, s]);
            if (s.complete)
              s.complete(data, status);
            xml = null;
           } catch(e)
             {
          
            status = "error";
            jQuery.handleError(s, xml, status, e);
           }

           // The request was completed
           if(s.global)
             jQuery.event.trigger( "ajaxComplete", [xml, s] );
           // Handle the global AJAX counter
           if (s.global && ! --jQuery.active )
             jQuery.event.trigger("ajaxStop");

           // Process result
   
        }
     }catch(ex){
       alert(ex.message);
     };
    }
    this.start=function(){jForm.submit();jIO.load(_this.onLoad);};
    return this;
     
  },
  createUploadForm: function(id, url,fileElementId, data)
  {
    //create form  
    var formId = &#39;jUploadForm&#39; + id;
    var fileId = &#39;jUploadFile&#39; + id;
    var form = jQuery(&#39;<form action="&#39;+url+&#39;" method="POST" name="&#39; + formId + &#39;" id="&#39; + formId + &#39;" enctype="multipart/form-data"></form>&#39;);  
    if(data)
    {
      for(var i in data)
      {
        jQuery(&#39;<input type="hidden" name="&#39; + i + &#39;" value="&#39; + data[i] + &#39;" />&#39;).appendTo(form);
      }      
    }  

    var oldElement = jQuery(&#39;#&#39; + fileElementId);
    var newElement = jQuery(oldElement).clone();
    jQuery(oldElement).attr(&#39;id&#39;, fileId);
    jQuery(oldElement).before(newElement);
    jQuery(oldElement).appendTo(form);

    //set attributes
    jQuery(form).css(&#39;position&#39;, &#39;absolute&#39;);
    jQuery(form).css(&#39;top&#39;, &#39;-1200px&#39;);
    jQuery(form).css(&#39;left&#39;, &#39;-1200px&#39;);
    jQuery(form).appendTo(&#39;body&#39;);    
    return form;
  },
  ajaxFileUpload: function(s) {
    // TODO introduce global settings, allowing the client to modify them for all requests, not only timeout  
    // Create the request object
    var xml = {};
    s = jQuery.extend({}, jQuery.ajaxSettings, s);
    if(window.ActiveXObject){
      var upload = new jQuery.ajaxUpload(s,xml);
      upload.start();
     
    }else{
    var id = new Date().getTime();
    var form = jQuery.createUploadForm(id,s.url, s.fileElementId, (typeof(s.data)==&#39;undefined&#39;?false:s.data));
    var io = jQuery.createUploadIframe(id, s.secureuri);
    var frameId = &#39;jUploadFrame&#39; + id;
    var formId = &#39;jUploadForm&#39; + id;    
    // Watch for a new set of requests
    if ( s.global && ! jQuery.active++ )
    {
      jQuery.event.trigger( "ajaxStart" );
    }      
    var requestDone = false;
  
    if ( s.global )
      jQuery.event.trigger("ajaxSend", [xml, s]);
    // Wait for a response to come back
    var uploadCallback = function(isTimeout)
    {      
      var io = document.getElementById(frameId);
  
      try
      {        
        if(io.contentWindow)
        {
           xml.responseText = io.contentWindow.document.body?io.contentWindow.document.body.innerHTML:null;
           xml.responseXML = io.contentWindow.document.XMLDocument?io.contentWindow.document.XMLDocument:io.contentWindow.document;
           
        }else if(io.contentDocument)
        {
           xml.responseText = io.contentDocument.document.body?io.contentDocument.document.body.innerHTML:null;
           xml.responseXML = io.contentDocument.document.XMLDocument?io.contentDocument.document.XMLDocument:io.contentDocument.document;
        }            
      }catch(e)
      {
        jQuery.handleError(s, xml, null, e);
      }
      if ( xml || isTimeout == "timeout")
      {        
        requestDone = true;
        var status;
        try {
          status = isTimeout != "timeout" ? "success" : "error";
          // Make sure that the request was successful or notmodified
          if ( status != "error" )
          {
            // process the data (runs the xml through httpData regardless of callback)
            var data = jQuery.uploadHttpData(xml, s.dataType);  
            // If a local callback was specified, fire it and pass it the data
      
            if (s.success)
              s.success(data, status);
  
            // Fire the global callback
            if(s.global)
              jQuery.event.trigger("ajaxSuccess", [xml, s]);
            if (s.complete)
              s.complete(data, status);
            
          } else
            jQuery.handleError(s, xml, status);
        } catch(e)
        {
          status = "error";
          jQuery.handleError(s, xml, status, e);
        }

        // The request was completed
        if(s.global)
          jQuery.event.trigger( "ajaxComplete", [xml, s] );
        // Handle the global AJAX counter
        if (s.global && ! --jQuery.active )
          jQuery.event.trigger("ajaxStop");

        // Process result
        jQuery(io).unbind();

        setTimeout(function()
                  {  try
                    {
                      jQuery(io).remove();
                      jQuery(form).remove();  
                      
                    } catch(e)
                    {
                      jQuery.handleError(s, xml, null, e);
                    }                  

                  }, 100);

        xml = null;

      }
    };
    // Timeout checker
    if (s.timeout>0)
    {
      setTimeout(function(){
        // Check to see if the request is still happening
        if( !requestDone ) uploadCallback("timeout");
      }, s.timeout);
    }
   
      try
        {
    
          var form = jQuery(&#39;#&#39; + formId);
          jQuery(form).attr(&#39;action&#39;, s.url);
          jQuery(form).attr(&#39;method&#39;, &#39;POST&#39;);
          jQuery(form).attr(&#39;target&#39;, frameId);
          
          if(form.encoding)
          {
            jQuery(form).attr(&#39;encoding&#39;, &#39;multipart/form-data&#39;);         
          }
          else
          {  
            jQuery(form).attr(&#39;enctype&#39;, &#39;multipart/form-data&#39;);      
          }  
     
          
          jQuery(form).submit();
    
        } catch(e)
        {  
          jQuery.handleError(s, xml, null, e);
        }
        
        jQuery(&#39;#&#39;+ frameId).load(uploadCallback);
        return {abort: function () {}};  
 
    }
  },

  uploadHttpData: function( r, type ) {
    
    var data = !type;
    data = type == "xml" || data ? r.responseXML : r.responseText;
    // If the type is "script", eval it in global context
    if ( type == "script" )
      jQuery.globalEval( data );
    // Get the JavaScript object, if JSON is used.
    if ( type == "json" ){
 
      eval( "data = " + $(data).html() );
    }
    // evaluate scripts within html
    if ( type == "html" )
      jQuery("<p>").html(data).evalScripts();
 
    return data;
  }
});

【相关推荐】

1. Java免费视频教程

2. JAVA教程手册

3. Java实现图片等比例缩略图视频教程

以上是用ajaxfileupload实现无刷新上传的代码示例的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
在平台独立性的平台独立性上使用字节码优于本机代码的优点是什么?在平台独立性的平台独立性上使用字节码优于本机代码的优点是什么?Apr 30, 2025 am 12:24 AM

ByteCodeachievesPlatFormIndenceByByByByByByExecutedBoviratualMachine(VM),允许CodetorunonanyplatformwithTheApprepreprepvm.Forexample,Javabytecodecodecodecodecanrunonanydevicewithajvm

Java真的100%独立于平台吗?为什么或为什么不呢?Java真的100%独立于平台吗?为什么或为什么不呢?Apr 30, 2025 am 12:18 AM

Java不能做到100%的平台独立性,但其平台独立性通过JVM和字节码实现,确保代码在不同平台上运行。具体实现包括:1.编译成字节码;2.JVM的解释执行;3.标准库的一致性。然而,JVM实现差异、操作系统和硬件差异以及第三方库的兼容性可能影响其平台独立性。

Java的平台独立性如何支持代码可维护性?Java的平台独立性如何支持代码可维护性?Apr 30, 2025 am 12:15 AM

Java通过“一次编写,到处运行”实现平台独立性,提升代码可维护性:1.代码重用性高,减少重复开发;2.维护成本低,只需一处修改;3.团队协作效率高,方便知识共享。

为新平台创建JVM面临哪些挑战?为新平台创建JVM面临哪些挑战?Apr 30, 2025 am 12:15 AM

在新平台上创建JVM面临的主要挑战包括硬件兼容性、操作系统兼容性和性能优化。1.硬件兼容性:需要确保JVM能正确使用新平台的处理器指令集,如RISC-V。2.操作系统兼容性:JVM需正确调用新平台的系统API,如Linux。3.性能优化:需进行性能测试和调优,调整垃圾回收策略以适应新平台的内存特性。

Javafx库如何试图解决GUI开发中的平台不一致?Javafx库如何试图解决GUI开发中的平台不一致?Apr 30, 2025 am 12:01 AM

javafxeffectife addressEddressEndressInconSiscies uningies uningusing inaplatform-agnosticsCenegraphandCssStyling.1)itabstractsplactsplatsplatsplatsplatformsthercensthascenegenceenceNaSceneGraph,确保ConsistSistEntertRenderingRenderingRenderingRenderingAccomWindows,MacOs,MacOS,MacOS,andlinux.2)

说明JVM如何充当Java代码和基础操作系统之间的中介。说明JVM如何充当Java代码和基础操作系统之间的中介。Apr 29, 2025 am 12:23 AM

JVM的工作原理是将Java代码转换为机器码并管理资源。1)类加载:加载.class文件到内存。2)运行时数据区:管理内存区域。3)执行引擎:解释或编译执行字节码。4)本地方法接口:通过JNI与操作系统交互。

解释Java虚拟机(JVM)在Java平台独立性中的作用。解释Java虚拟机(JVM)在Java平台独立性中的作用。Apr 29, 2025 am 12:21 AM

JVM使Java实现跨平台运行。1)JVM加载、验证和执行字节码。2)JVM的工作包括类加载、字节码验证、解释执行和内存管理。3)JVM支持高级功能如动态类加载和反射。

您将采取哪些步骤来确保Java应用程序在不同的操作系统上正确运行?您将采取哪些步骤来确保Java应用程序在不同的操作系统上正确运行?Apr 29, 2025 am 12:11 AM

Java应用可通过以下步骤在不同操作系统上运行:1)使用File或Paths类处理文件路径;2)通过System.getenv()设置和获取环境变量;3)利用Maven或Gradle管理依赖并测试。Java的跨平台能力依赖于JVM的抽象层,但仍需手动处理某些操作系统特定的功能。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境