`
axl234
  • 浏览: 268947 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Ajax Upload文件上传插件 替代(<input type=”file” />)上传图片

阅读更多
1、Ajax Upload上传插件

浏览器迫使我们使用文件输入控件(<input type=”file” />)做上传,然而此控件的样式是不能修改的。此外,基于表单上传在流行的Ajax应用程序面前显得过时了。我们可以使用flash解决这个问题,但实际上JavaScript也能做的很出色。

Ajax Upload文件上传插件允许你上传多个插件而无需刷新页面,可以使用任何的元素来显示文件选择窗口。它可以在所有主流的浏览器下工作,从2.0版本开始,不需要任何库运行。Ajax Upload文件上传插件不会污染任何命名空间,所以它与jQuery,Prototypejs,mootools其他JavaScript库兼容。

Demo实例
下面是一个在jQuery下使用Ajax Upload插件的实例。

下载
版本3.6 发布于2009-03-10

问题,贡献和最新版本
该项目最近已经移到了GitHub,欢迎您去折腾它。也更愿意您使用“问题跟踪(issue tracker)”留下意见,错误报告和要求。您必须先要在GitHub上注册才行。

2、如何去使用它?

创建上载
首先,您需要创建一个按钮。(可以使用任意的元素)

<div id=”upload_button”>上传</div>
接下来,您应该创建Ajax上传实例。您可以使用以下代码创建最简单的形式:

// 您必须在 DOM 准备好之后在创建它
//在jquery下使用 $(document).ready
// prototype下为document.observe(“dom:loaded”
new AjaxUpload(‘upload_button_id’, {action: ‘upload.php’});
配置Ajax上传

new AjaxUpload(‘#upload_button_id’, {
// 服务器端上传脚本
// 注意: 文件不允许上传到另外一个域上
action: ‘upload.php’,
// 文件上传的名字
name: ‘userfile’,
// 发送的附加数据
data: {
example_key1 : ‘example_value’,
example_key2 : ‘example_value2′
},
// 筛选后提交文件
autoSubmit: true,
// 您希望从服务器返回的数据类型
// HTML (text) 和 XML 自动检测
// 当您使用JSON作为响应时很实用,在这种情况下就设置为 “json”
// 也要设置服务器端的响应类型为text/html, 否则在IE6下是不工作的
responseType: false,
// 文件选择后使用
// 当autoSubmit为disabled时很管用
// 您可以通过返回false取消上传
// @参数file为上传文件的文件名
// @参数extension为那个文件(后缀名)
onChange: function(file, extension){},
// 文件上传时调用
// 您可以通过设置返回false 取消上传
// @参数file为上传文件的文件名
// @参数extension为那个文件(后缀名)
onSubmit: function(file, extension) {},
// 当文件上传完成的时候调用
// 警告!不要使用”false”字符串作为服务器的响应
// @参数file 指上传的文件名
// @参数 response 指服务器的响应
onComplete: function(file, response) {}
});
注意:不要使用数据参数附加动态数据,就像“data: (txt:textfield.value)”,因为它将在AJAX Upload实例创建的时候分配数据且以后不会改变。如果你想文本框的传递的其他数据,使用在onSubmit回调函数中的SetData方法。

实例方法
*submit – 提交文件到服务器(当autoSubmit被禁用时有用)
*disable – 禁用上传按钮
*enable – 允许上传按钮
*destroy – 清理AjaxUpload对象
* setData(data) – 覆盖数据参数

//您可以使用这些方法来配置AJAX的上传
var upload = new AjaxUpload(‘#div_id’,{action: ‘upload.php’});
//例如当用户选择了一些东西,设置一些参数
upload.setData({‘example_key’: ‘value’});//或者您可以在事件函数中直接使用这些方法
new AjaxUpload(‘div_id’, {
action: ‘upload.php’,
onSubmit: function() {
//仅允许一个上传
this.disable();
}
});
});
3、如何访问上载的文件?
对于服务器端的代码,文件似乎是以简单的形式被上传,所以您可以使用任何您想用的语言。
您访问上传文件可以使用:
* PHP: $_FILES['userfile']
* Rails: params[:userfile]
请注意,’userfile’是”name”选项的默认值

您可以访问其他一些参数通过:
* PHP: $_POST['yourkey']
* Rails: params[:yourkey]

服务器端脚本
如果您使用的是PHP的,这里是一个简单的例子,我从PHP手册直接获得的。

$uploaddir = ‘/var/www/uploads/’;
$uploadfile = $uploaddir . basename($_FILES['userfile']['name']);

if (move_uploaded_file($_FILES['userfile']['tmp_name'], $uploadfile)) {
echo “success”;
} else {
// 警告!不要使用字符串”FALSE”作为一个响应!
// 否则onSubmit 事件不会调用
echo “error”;
}

ColdFusion的文件上传。 (默认准系统解决方案)

<cffunction name=”uploadFile” access=”remote” output=”false”>
<cfargument name=”userFile”>
<cffile action=”upload” fileField=”userFile” destination=”directory/path/on/server/”>
<cfreturn “whatever”>
</cffunction>

这里是一个ASPX处理程序,请进行修改以满足您的需要:

using System;
using System.Web;
using System.IO;
public class FileHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
string strFileName = Path.GetFileName(context.Request.Files[0].FileName);
string strExtension = Path.GetExtension(context.Request.Files[0].FileName).ToLower();
string strSaveLocation = context.Server.MapPath(“Upload”) + “” + strFileName;
context.Request.Files[0].SaveAs(strSaveLocation);
context.Response.ContentType = “text/plain”;
context.Response.Write(“success”);
}
public bool IsReusable
{
get
{
return false;
}
}
}
4、如何只允许某些文件类型?
最好的方法是检查在onSubmit回调函数选定的文件类型,并让函数返回false取消上传选中的无效的文件。但是不要忘记添加一个服务器端的安全检查。

new AjaxUpload(‘#button2′, {
action: ‘upload.php’,
onSubmit : function(file , ext){
if (! (ext && /^(jpg|png|jpeg|gif)$/.test(ext))){
// 扩展名不允许
alert(‘错误:无效的文件扩展名!’);
// 取消上传
return false;
}
}
});
5、如何工作的?
插件创建隐形的文件域控件在您提供的按钮上。所以,当用户点击您的按钮时,正常的文件选择窗口就会显示。之后用户选择一个文件,插件提交包含文件输入框控件的表单到一个iframe中。因此,这不是真正的Ajax上传,但同时带来了用户体验。

6、授权与使用条款
Ajax Upload 上传插件是完全免费的,服从MIT license使用许可。

二、我使用php制作的最简单的图片上传使用演示

首先,看图,简述操作。
1. 单击按钮,选择图片

2. 选择数张图片,例如这里我选了三张,选完及上传,结果如下

3. 结果在uploads文件夹下面就可以看到刚刚上传的三张图片了


代码请参考Demo或源文件。

您可以狠狠地单击这里:中文Demo页面 | 精简版源文件下载

说明:
1、源文件下载至本地,需要修改文件处理php页面代码的路径。需要将此路径对应于您新建的用以存放图片或其他文件的文件夹;
2、源文件与在线Demo有差别,源文件中的Demo无logo,排版,广告等,纯粹的Demo,代码简洁,应该会有帮助。
3、本实例是能上传图片,您可以去掉正则判断,使支持其他格式。
4、本实例没有使用JavaScript库做辅助,这是由于本身Ajax Upload文件上传插件就是纯粹的JavaScript写的,所以不依赖于任何的JavaScript库,可以直接使用JavaScript实现多文件上传。
5、在线Demo请勿上传敏感的图片,谢谢合作。

分享到:
评论

相关推荐

    一次性选择多文件上传multiple属性

    一种常见的方法是使用Flash或Silverlight插件,或者利用JavaScript和Ajax技术模拟多文件选择和上传。例如,通过监听`change`事件,每次用户选择文件后,将其上传,并清空当前的文件选择,然后再次触发文件选择对话框...

    HTML5视频上传(包含html5自带拍照,录像,音频,附件)

    在视频上传场景中,我们可以创建一个`&lt;input type="file"&gt;`元素,设置其`accept`属性为`.mp4, .webm, .ogg`等视频格式,以限制用户只能选择视频文件进行上传。 ```html &lt;input type="file" accept="video/mp4, ...

    input file选择文件之后自动上传(样式自定义美化)

    通过使用`&lt;input type="file"&gt;`、事件监听和`$.ajaxFileUpload`,我们可以构建出既美观又功能强大的文件上传组件,提升用户的使用体验。同时,对于开发者来说,理解这些技术原理并熟练应用,是提升Web开发技能的重要...

    ajaxfileupload.js结合input[type=file]无刷新上传

    本文将详细介绍如何使用`ajaxfileupload.js`这个jQuery插件,结合`input[type=file]`元素,实现无刷新的文件上传功能。 首先,`ajaxfileupload.js`是一个基于jQuery的轻量级插件,它允许开发者通过异步方式发送文件...

    springmvc+jquery+layui文件上传进度条

    为了支持多文件上传,我们需要在HTML表单中使用`&lt;input type="file" multiple&gt;`,并调整jQuery代码来处理多个文件。在Spring MVC中,`MultipartFile[] files`可以接收多个文件: ```java @PostMapping("/upload") ...

    【JavaScript源代码】Ajax 文件上传进度监听之upload.onprogress案例详解.docx

    ### JavaScript 源代码:Ajax 文件上传进度监听之upload.onprogress案例详解 #### 一、概述 在Web开发中,文件上传是一项常见的功能需求。为了提高用户体验,开发者往往需要实现文件上传过程中的进度显示功能。这...

    Python - Flask 使用Ajax 实现多文件上传

    要实现多文件上传,HTML表单需要包含多个文件输入字段,如`&lt;input type="file" multiple&gt;`。`multiple`属性允许用户选择多个文件。然后,这些文件可以通过Ajax发送到服务器。 **四、Ajax技术** Ajax(Asynchronous ...

    spring 文件上传.rar

    &lt;input type="submit" value="上传文件"&gt; &lt;/form&gt; ``` 注意,文件上传的安全性至关重要。在实际应用中,应确保对上传文件的类型、大小进行限制,并对上传路径进行安全设置,防止路径遍历攻击。此外,还需要考虑...

    php无刷新图片上传

    注意,为了支持多个文件上传,`&lt;input type="file"&gt;`标签的`multiple`属性应该被设置。 ```html &lt;form id="upload-form" enctype="multipart/form-data"&gt; &lt;input type="file" name="image" id="image-input" ...

    jquery文件上传插件(多文件选择、带进度条 ,图片预览)

    &lt;title&gt;jQuery文件上传插件&lt;/title&gt; &lt;script src="https://code.jquery.com/jquery-3.6.0.min.js"&gt;&lt;/script&gt; &lt;link rel="stylesheet" href="webuploader/webuploader.css"&gt; &lt;script src="webuploader/...

    jspSmartUpload的使用—实现文件上传.pdf

    -- 因为上传的是图片,即文件,所以type="file" --&gt; &lt;/tr&gt; &lt;tr&gt; &lt;th&gt;&lt;/th&gt; &lt;td&gt;&lt;input class="btn btn-primary btn6 mr10" value="提交" type="submit"&gt;&lt;input class="btn btn6" onClick="history.go(-1)" value...

    ajax异步文件上传,servlet处理

    用户通过`&lt;input type="file"&gt;`选择文件后,将文件添加到`FormData`对象,然后通过XMLHttpRequest发送请求。 ### 2. 创建HTML表单 首先,我们需要一个包含文件选择控件的HTML表单: ```html &lt;form id="uploadForm...

    用easyui-filebox上传Excel文件(ASP.NET MVC)

    &lt;input type="file" class="easyui-filebox" data-options="onSuccess:function(result){console.log(result);}" /&gt; &lt;script&gt; // 可以在这里添加一些额外的JavaScript代码,例如设置FileBox的事件处理函数 &lt;/...

    Base64和AjaxUpload上传文件代码实例

    Base64和AjaxUpload上传文件代码实例 Base64和AjaxUpload上传文件代码实例是两种常用的文件上传方式,它们都可以实现文件上传到服务器端,但它们之间有着明显的区别。 Base64上传文件是一种基于文本编码的上传方式...

    Struts2文件上传带进度条页面无刷新

    "Struts2文件上传带进度条页面无刷新"的实现涉及多个技术点,包括Struts2的文件上传插件、AJAX异步通信以及前端进度条展示。 首先,Struts2的文件上传依赖于`struts2-upload-plugin`。这个插件扩展了Struts2的核心...

    php upload文件上传代码 jquery ajax无刷新

    2. **jQuery和AjaxUpload插件**:引入jQuery库和AjaxUpload插件的JavaScript文件,然后编写JavaScript代码来绑定事件和处理上传。 ```javascript $(document).ready(function() { var options = { url: 'upload....

    upload上传JS

    接着,创建一个包含`&lt;input type="file"&gt;`的表单元素,通过设置`multiple`属性可以支持多选文件上传。在JavaScript中,我们需要初始化插件,指定上传的URL以及一些配置选项,例如是否显示进度条、错误处理方式等。 ...

    Nginx文件上传进度显示

    &lt;input type="file" id="fileToUpload" name="fileToUpload" /&gt; &lt;button onclick="return uploadfile()"&gt;上传文件&lt;/button&gt; &lt;/form&gt; &lt;div id="progress"&gt;&lt;/div&gt; &lt;/body&gt; &lt;/html&gt; ``` #### 四、总结 Nginx 的 `...

    Jquery AjaxUpload实现文件上传实例 PHP版

    AjaxUpload是jQuery的一个插件,它提供了一种方便的异步文件上传方式,无需刷新页面即可完成文件上传,提高了用户体验。在这个“Jquery AjaxUpload实现文件上传实例 PHP版”中,我们将探讨如何使用jQuery的Ajax...

Global site tag (gtag.js) - Google Analytics