zoukankan      html  css  js  c++  java
  • (H5)FormData+AJAX+SpringMVC跨域异步上传文件

      最近都没时间整理资料了,一入职就要弄懂业务,整天被业务弄得血崩。

      总结下今天弄了一个早上的跨域异步上传文件。主要用到技术有HTML5的FormData,AJAX,Spring MVC。

      首先看下上传页面:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <script type="text/javascript" src="js/plugins/jquery-1.8.3.min.js" ></script>
            <title></title>
        </head>
        <body>
            <input type="file" id="file_upload"/>
            <input type="button" value="上传图片" id="upload"/>            
        </body>
        <script type="text/javascript" src="js/upload.js" ></script>
    </html>

      上传页面很简单,就两个input元素。

      然后看下upload.js。注意这个upload.js是自己写的,里面那个ajaxFileUpload并不是jQuery提供的那个上传插件的方法。

    $(document).ready(function(){
        
        function ajaxFileUpload(){
            var formData = new FormData();
            formData.append('file',$("#file_upload")[0].files[0]);    //将文件转成二进制形式
            $.ajax({
                type:"post",
                url:"http://localhost:8080/nitshareserver/serve/fileupload",
                async:false,
                contentType: false,    //这个一定要写
                processData: false, //这个也一定要写,不然会报错
                data:formData,
                dataType:'text',    //返回类型,有json,text,HTML。这里并没有jsonp格式,所以别妄想能用jsonp做跨域了。
                success:function(data){
                    alert(data);
                },
                error:function(XMLHttpRequest, textStatus, errorThrown, data){
                    alert(errorThrown);
                }            
            });
        }
        
        $("#upload").click(function(){
            ajaxFileUpload();
        });
    });

      前端这样就可以了,接下来看看服务端的写法。

      服务端接口写法:

    //    @ResponseBody
        @RequestMapping(value="fileupload", method=RequestMethod.POST,produces="text/html;charset=utf-8")
        public void addPic(HttpServletResponse response,HttpServletRequest request,
                @RequestParam(value="file", required=false) MultipartFile file) throws IOException{
            System.out.println(file.getOriginalFilename());
            response.getWriter().write("success");
            response.setHeader("Access-Control-Allow-Origin", "*");
    //        return "success";
        }

      这里response.setHeader("Access-Control-Allow-Origin", "*");这句很重要,没有这句,前端接收不到返回的数据。Access-Control-Allow-Origin是HTML5中定义的一种服务器端返回Response header,用来解决资源(比如字体)的跨域权限问题。它定义了该资源允许被哪个域引用,或者被所有域引用(google字体使用*表示字体资源允许被所有域引用),但是在真正的产品中,是不会用*的。这里只是好方便演示。

      那跑一下工程,看看前端会不会收到success吧。

      结果:

    结果

    服务端控制台:

    结果1

    转载注明出处:http://www.cnblogs.com/BigDreamer/

  • 相关阅读:
    Java实现币值最大化问题
    Java实现币值最大化问题
    Java实现币值最大化问题
    Java实现币值最大化问题
    ddd
    雷军:小米最坏的时候已过去 2017目标营收千亿(确实有些新意)
    真正的转变从不确定中来
    很多人知道自己的斤两,他之所以抱怨工资低,不是觉得薪水和自己的能力不匹配,而是因为工资确实不够用(笑死了)
    CodeSmith
    sb2-admin
  • 原文地址:https://www.cnblogs.com/BigDreamer/p/5506340.html
Copyright © 2011-2022 走看看