Ajax 无刷新上传文件插件 uploadify 的使用

在表单中无法直接使用 Ajax 上传文件,解决的思路可以是使用插件无刷新地上传文件,返回文件上传后的地址,然后把该地址作为 Ajax 的参数传递给服务器端进行数据库处理。可以使用 uploadify 插件来实现该思路。

官方网站:http://www.uploadify.com

文档地址:http://www.uploadify.com/documentation/

插件有 Flash 版 和 HTML5 版,项目中用到的是 Flash 版。

下载 Demo 并解压:

其中 index.php :包含了 html ,并且调用了核心 js 库的接口;

jquery.uploadify.js :核心 js 库;

uploadify.php :处理上传,并且返回上传是否成功的状态值。

对官方 demo 稍作修改:

index.html 主要代码

<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="__PUBLIC__/css/uploadify.css" type="text/css">
<script src="__PUBLIC__/js/Jquery-1.8.3.js.js"></script>
<script src="__PUBLIC__/js/jquery.uploadify.js" type="text/javascript"></script>
<script src="__PUBLIC__/js/upload.js" type="text/javascript"></script>
</head>

<body>
<form id="upform" style="display:none">
    <div id="queue"></div>
    <input id="file_upload" name="file_upload" type="file" multiple="true">
</form>
</body>
</html>

upload.js 代码:

$(function(){
    $timestamp = $("#timestamp").html();
    $token = $("#token").html();
    $swfurl = $("#swfurl").html();
    $(‘#file_upload‘).uploadify({
        ‘formData‘     : {
            ‘timestamp‘ : $timestamp,
            ‘token‘     : $token
        },
        ‘swf‘      : $swfurl,
        ‘uploader‘ : ‘uploadify.php‘,
        ‘onUploadSuccess‘ : function(file, data, response) {
            var dataObj = eval("(" + data + ")");
            if(1 == dataObj.code){
                $msg = ‘文件‘+ file.name + ‘上传成功‘;
                $("#msg").html($msg);
                $("#filename").html(dataObj.filename);
            }else if(2 == dataObj.code){
                $msg = ‘文件上传失败,请上传小于2M的.dox、.docx、.pdf文件‘;
                layer.msg($msg, 2, 3);
            }else if(3 == dataObj.code){
                $msg = ‘文件类型错误‘;
                layer.msg($msg, 2, 3);
            }else{
                $msg = ‘上传失败,请上传小于2M的.dox、.docx、.pdf文件‘;
                layer.msg($msg, 2, 3);
            }
        }
    });
})

uploadify.php

<?php
$targetFolder = ‘./Uploads/authorization‘;
$verifyToken = md5(‘unique_salt‘ . $_POST[‘timestamp‘]);

if (!empty($_FILES) && $_POST[‘token‘] == $verifyToken) {
    $tempFile = $_FILES[‘Filedata‘][‘tmp_name‘];
    $targetPath = $_SERVER[‘DOCUMENT_ROOT‘] . $targetFolder;

    $fileTypes = array(‘doc‘,‘docx‘,‘pdf‘);
    $fileParts = pathinfo($_FILES[‘Filedata‘][‘name‘]);

    $filename = $_SESSION[‘member‘][‘mid‘].‘-‘.date(‘Ymd-His‘).‘-‘.  mt_rand(0,1000).‘.‘.$fileParts[‘extension‘];
    $targetFile = rtrim($targetPath,‘/‘) . ‘/‘ . $filename;

    if (in_array($fileParts[‘extension‘],$fileTypes)) {
        if(move_uploaded_file($tempFile,$targetFile)){
            $arr[‘code‘]= 1;
        }else{
            //上传失败
            $arr[‘code‘] = 2;
            $arr[‘file_name‘] = ‘‘;
        }
    } else {
        //文件类型错误
        $arr[‘code‘] = 3;
        $arr[‘file_name‘] = ‘‘;
    }
}else{
    $arr[‘code‘] = 4;
    $arr[‘file_name‘] = ‘‘;
}
$arr[‘filename‘] = $filename;
exit(json_encode($arr));
时间: 2024-11-03 03:34:45

Ajax 无刷新上传文件插件 uploadify 的使用的相关文章

jquery 的ajax无刷新上传文件之后,页面还是会莫名的刷新-----解决办法

文件上传用到全局数组: $_FILES 只需要把下面的 <button onclick="post()">提交</button> 改为 <input type="button" onclick="post()" value="提交"/>就不会刷新页面了!!! 参考 http://bbs.csdn.net/topics/391852021 what fuck ... sb html   我在那

ajaxfileupload.js插件结合一般处理文件实现Ajax无刷新上传

先上几张图更直观展示一下要实现的功能.本功能主要通过Jquery ajaxfileupload.js插件结合ajaxUpFile.ashx一般应用程序处理文件实现Ajax无刷新上传功能,结合NPOI2.0实现数据读取.这个功能在实际工作种经经常使用到,希望能给须要做这方面的人有些帮助. 一.功能页面布局及介绍 1.上传页面布局及input file上传功能 2.上传页面文件正在上传效果 3.上传完毕效果,多文件展示区 二.功能代码实现及资源引用 1.js资源文件引用 html页面js引用.须要引

ajax jsp 无刷新上传文件

本文实现的文件上传也是无页面刷新的,可以说是一种"类似AJAX"方法 开始之前先说两句无关的,其实在ajax出现之前,web应用也可以是无刷新的,那时大多通过IFrame来做到这一点.当然Ajax出现之后,人们一窝蜂地投奔Ajax 的阵营了,iFrame 就乏人问津了.但是用iFrame来实现无刷新上传文件确实一个很好的选择. ps:Ajax技术基本上可以说是由google公司带起来的,但少Gmail中上传文件用的还是 IFrame,所以使用IFrame来上传文件是最好的选择. 我在这

移动端图片上传解决方案localResizeIMG先压缩后ajax无刷新上传

现在科技太发达,移动设备像素越来越高,随便一张照片2M+,但是要做移动端图片上传和pc上略有不同,移动端你不能去限制图片大小,让用户先处理图片再上传,这样不现实.所以理解的解决方案就是在上传先进行图片压缩,然后再把压缩后的图片上传到服务器. 一翻google之后,发现了localResizeIMG,它会对图片进行压缩成你指定宽度及质量度并转换成base64图片格式,那么我们就可以把这个base64通过ajax传到后台,再进行保存,先压缩后上传的目的就达到了. 处理过程 LocalResizeIM

异步无刷新上传文件并且上传文件可以带上参数

关于异步上传文件并且带上参数,网上有很多关于这样的插件,而我最喜欢用的插件是ajaxfileupload.js,该插件的代码如下: /*   131108-xxj-ajaxFileUpload.js 无刷新上传图片 jquery 插件,支持 ie6-ie10    依赖:jquery-1.6.1.min.js   主方法:ajaxFileUpload 接受 json 对象参数   参数说明:   fileElementId:必选,上传文件域ID   url:必选,发送请求的URL字符串   fi

动端图片上传解决方案localResizeIMG先压缩后ajax无刷新上传

现在科技太发达,移动设备像素越来越高,随便一张照片2M+,但是要做移动端图片上传和pc上略有不同,移动端你不能去限制图片大小,让用户先处理图片再上传,这样不现实.所以理解的解决方案就是在上传先进行图片压缩,然后再把压缩后的图片上传到服务器. 一翻google之后,发现了localResizeIMG,它会对图片进行压缩成你指定宽度及质量度并转换成base64图片格式,那么我们就可以把这个base64通过ajax传到后台,再进行保存,先压缩后上传的目的就达到了. 处理过程 LocalResizeIM

iframe实现无刷新上传文件(转)

其实在ajax出现之前,web应用也可以是无刷新的,那时大多通过IFrame来做到这一点.当然Ajax出现之后,人们一窝蜂地投奔Ajax 的阵营了,iFrame 就乏人问津了.但是用iFrame来实现无刷新上传文件确实一个很好的选择. [1].[代码] [HTML]代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 <html>   <body>      <form action="upload.jsp

隐藏iframe无刷新上传文件

首先ajax不能上传文件,这误导了我有段时间,今晚睡不着就照着说明做了个无刷新上传文件 其实原理很简单 <form enctype="multipart/form-data" method="POST" target="upload" action="http://localhost/class.upload.php" > <input type="file" name="upl

web 开发之js---巧用iframe实现jsp无刷新上传文件

首先要说的就是 ajax 是无法实现上传文件的,可以想一下ajax与后台通信都是通过传递字符串,怎么能传递文件呢?其实出于安全考虑js是不能操作文件的,所以就不要再说用ajax来实现文件的上传了,这是不可能的.    而本文实现的文件上传也是无页面刷新的,可以说是一种"类似AJAX"方法.    开始之前先说两句无关的,其实在ajax出现之前,web应用也可以是无刷新的,那时大多通过IFrame来做到这一点.当然Ajax出现之后,人们一窝蜂地投奔Ajax 的阵营了,iFrame 就乏人