AjaxFileUpload.js并不是一个很出名的插件,只是别人写好的放出来供大家用,原理都是创建隐藏的表单和iframe然后用JS去提交,获得返回值。

  它的配置方式比较像jQuery的AJAX,使用比较方便

  语法:$.ajaxFileUpload([options])

  参数:

    1,url          上传处理程序地址。  
    2,fileElementId      需要上传的文件域的ID,即<input type="file">的ID。
    3,secureuri        是否启用安全提交,默认为false。 
    4,dataType        服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。
    5,success         提交成功后自动执行的处理函数,参数data就是服务器返回的数据。
    6,error         提交失败自动执行的处理函数。
    7,data          自定义参数。这个东西比较有用,当有数据是与上传的图片相关的时候,这个东西就要用到了。
    8, type           当要提交自定义参数时,这个参数要设置成post

  使用步骤:

  第一步:导入JQuery和ajaxFileUpload的js文件

  1. <script type="text/javascript" src="js/jquery-1.11.2.min.js"></script>
  2. <script type="text/javascript" src="js/ajaxfileupload.js"></script>

  第二步:HTML代码

  1. <div style="width:200px;">
  2. <p><img id="img" src="" alt="头像"/></p>
  3. <p><input type="file" id="file" name="file" onchange="imgPreview();"/></p>
  4. <p>账户:<input type="text" id="username"/></p>
  5. <p>密码:<input type="password" id="password"/></p>
  6. <p><input type="button" value="注册" onclick="register();"/></p>
  7. </div>

  第三步:JS代码

  1. /*
  2. 用户—注册
  3. */
  4. function register(){
  5. //获取账户
  6. var username = $('#username').val().trim();
  7. if(username==null || username==''){
  8. alert('账户为空!');
  9. return false;
  10. }
  11. //获取密码
  12. var password = $('#password').val().trim();
  13. if(password==null || password==''){
  14. alert('密码为空!');
  15. return false;
  16. }
  17. //获取文件
  18. var file = $('#file')[0].files[0];
  19. if(!file){
  20. alert('请上传头像文件!');
  21. return false;
  22. }
  23.  
  24. $.ajaxFileUpload({
  25. "url": 'register.do',
  26. "secureuri": false,
  27. "fileElementId": "file",
  28. "data": {"username":username,"password":password},
  29. "dataType": "text",
  30. "success": function(result){
  31. alert('注册成功!');
  32. },
  33. "error": function(result){
  34. alert('注册失败!');
  35. }
  36. });
  37. }

  第四步:后端java处理(spring)

     在使用MultipartHttpServletReuqest和MultipartFile类时,要对spring进行配置。

   具体见:http://www.cnblogs.com/gangbalei/p/6077791.html

  1. @RequestMapping(value="/register.do")
  2. public void upload(HttpServletRequest request) throws IOException{
  3. //获取ajaxFileUpload上传时data中传递的数据
  4. String username = request.getParameter("username");
  5. String password = request.getParameter("password");
  6.  
  7. // 判断request是否属于MultipartHttpServletRequest对象
  8. // if(request instanceof MultipartHttpServletRequest){
  9. // MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest)request;
  10. // MultipartFile mfile = multipartRequest.getFile("file");
  11. // }
  12.  
  13. //将request强转成MultipartHttpServletRequest对象
  14. MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest)request;
  15. //获取上传的文件
  16. MultipartFile mfile = multipartRequest.getFile("file");
  17.  
  18. //设置文件存放的位置
  19. File dir = new File("F:/upload");
  20. //如果目录不存在,则创建一个该目录
  21. if(!dir.exists()){
  22. dir.mkdir();
  23. }
  24. //获取上传的文件名
  25. String fileName = mfile.getOriginalFilename();
  26. //获取请求的输入流
  27. InputStream in = mfile.getInputStream();
  28. //读取输入流的数据
  29. byte[] buf = new byte[1048576];
  30. int length = in.read(buf);
  31. //文件存放的完成路径
  32. String path = dir.getAbsolutePath()+"//"+fileName;
  33. //新建输出流
  34. FileOutputStream out = new FileOutputStream(path);
  35. //将数据写入输出流中
  36. out.write(buf, 0, length);
  37. //关闭输入输出流
  38. in.close();
  39. out.close();
  40. }

  注意:

   使用ajaxFileUpload上传文件时,有时需要带参数提交,网上有很多资料说使用data,但其实要使用data带参数是需要修改的,否则后台是获取不到的.

    ajaxFileUpload为了实现无刷新异步提交文件,构建 iframe 然后创建form表单 再将要上传的文件写上去再提交.但是原代码 却没有处理data.所以这块内容需要我们自己加上去.

    下面红色部分为修改ajaxFileUpload.js的三处地方:

  1. createUploadForm: function(id, fileElementId,data)
  2. {
  3. var formId = 'jUploadForm' + id;
  4. var fileId = 'jUploadFile' + id;
  5. var form = $('<form action="" method="POST" name="' + formId + '" id="' + formId + '" enctype="multipart/form-data"></form>');
  6. var oldElement = $('#' + fileElementId);
  7. var newElement = $(oldElement).clone();
  8. $(oldElement).attr('id', fileId);
  9. $(oldElement).before(newElement);
  10. $(oldElement).appendTo(form);
  11. if (data) {
  12. for (var i in data) {
  13. $('<input type="hidden" name="' + i + '" value="' + data[i] + '" />').appendTo(form);
  14. }
  15. }
  16. //set attributes
  17. $(form).css('position', 'absolute');
  18. $(form).css('top', '-1200px');
  19. $(form).css('left', '-1200px');
  20. $(form).appendTo('body');
  21. return form;
  22. },

  在ajaxFileUpload: function(s)的内容中

  1. var form = jQuery.createUploadForm(id, s.fileElementId,s.data);

ajaxFileUpload 异步上传数据的更多相关文章

  1. 【转】JQuery插件ajaxFileUpload 异步上传文件(PHP版)

    前几天想在手机端做个异步上传图片的功能,平时用的比较多的JQuery图片上传插件是Uploadify这个插件,效果很不错,但是由于手机不支持flash,所以不得不再找一个文件上传插件来用了.后来发现a ...

  2. JQuery插件ajaxFileUpload 异步上传文件(PHP版)

    太久没写博客了,真的是太忙了.善于总结,进步才会更快啊.不多说,直接进入主题. 前几天想在手机端做个异步上传图片的功能,平时用的比较多的JQuery图片上传插件是Uploadify这个插件,效果很不错 ...

  3. jQuery插件之ajaxFileUpload异步上传

    介绍 AjaxFileUpload.js 是一个异步上传文件的jQuery插件,原理是创建隐藏的表单和iframe然后用JS去提交,获得返回值. 下载地址: http://files.cnblogs. ...

  4. struts2 jquery ajaxFileUpload 异步上传文件

    网上搜集的,整理一下. 一.ajaxFileUpload 实现异步上传文件利用到了ajaxFileUpload.js这个文件,这是别人开发的一个jquery的插件,可以实现文件的上传并能够和strut ...

  5. jquery之ajaxfileupload异步上传插件

    点我下载工程代码由于项目需求,在处理文件上传时需要使用到文件的异步上传.这里使用Jquery Ajax File Uploader这个组件下载地址:http://www.phpletter.com/d ...

  6. 【文件上传】jquery之ajaxfileupload异步上传插件

    来自:http://www.blogjava.net/sxyx2008/archive/2010/11/02/336826.html 由于项目需求,在处理文件上传时需要使用到文件的异步上传.这里使用J ...

  7. jquery ajaxFileUpload异步上传文件

    ajaxFileUpload.js 很多同名的,因为做出来一个很容易. 我用的是这个:https://github.com/carlcarl/AjaxFileUpload 下载地址在这里:http:/ ...

  8. JQuery插件ajaxFileUpload 异步上传文件

    一.先对ajaxFileUpload插件的语法参数进行讲解 原理:ajaxfileupload是通过监听iframe的onload方法来实现, 当从服务端处理完成后,就触发iframe的onload事 ...

  9. asp.net mvc 使用uploadfiles 实现异步上传数据

    lesg.cn 文章发布在:  http://www.lesg.cn/netdaima/net/2017-990.html 在实际开发过程中, 为了提高用户的体验,在上传文件的时候通常会使用异步上传文 ...

随机推荐

  1. 删除sqlserver代理任务脚本

    无法删除SQLSERVER代理任务时可用如下语句试验下 use [msdb] ) set @job_name = N'jobname' --注:job_name为维护计划对应的job name --删 ...

  2. 初学android之简易的网易页面

    WangYiActivity.java: public class WangYiActivity extends Activity implements OnClickListener{ public ...

  3. shell return value

  4. ckeditor插件

    插件下载地址:http://ckeditor.com/download 1.CKeditor配置 在html页面的<head>标签中引入核心文件 ckeditor.js <scrip ...

  5. windows下sass安装 以及一些要注意的问题

    都说sass 环境难配其时也没那么难 按照以下步骤一下一下来还是挺快的 如果你是喜欢less 那就当我没说 233333 1.sass 是基于ruby这门语言的需要使用 rubygem这个包管理器安装 ...

  6. Hibernate部署问题总结

    出现未知实体类(- org.hibernate.MappingException: Unknown entity),找不到cfg.xml包 (org.hibernate.internal.util.c ...

  7. 【Python】pymongo使用

    官方文档:http://api.mongodb.com/python/current/index.html MongoReplicaSetClient:http://api.mongodb.com/p ...

  8. JS学习知我见(常用建站代码)

    <!doctype html><html><head><meta charset="utf-8"><meta name=&qu ...

  9. 揭秘 typedef四用途与两陷阱[转]

    自 http://niehan.blog.techweb.com.cn/archives/325.html typedef用来声明一个别名,typedef后面的语法,是一个声明.本来笔者以为这里不会产 ...

  10. 命令与文件的查询 which whereis locate find

    一:which which查找脚本文件也就是我们的系统命令 用法:which [command] 默认根据我们PATH路径去查找,但是不同的用户肯定设置不同的PATH,所以就像普通用户查找不到一些/s ...