今天介绍的这款flash上传头像功能非常强大,支持php,asp,jsp,asp.net 调用 头像剪裁,预览组件插件。 本组件需要安装Flash Player后才可使用,请从http://dl.pconline.com.cn/html_2/1/114/id=8122&pn=0.html" target='_blank'>这里下载安装。

程序员,你不是一个人;网站开发QQ群:35291327 在线充值,或联系QQ416148489直接充值

分类:图片代码 > 缩略图 难易:中级
查看演示 下载资源: 3229下载资源 下载积分: 26 积分

该flash头像上传插件受众多开发人员好评的优秀,具有以下优势:

<ul class="ul_demo"> <li>上传并预览,用户可以任意选择区域,支持头像旋转</li> <li>支持上传成功,js 回调函数</li> <li>无论图片过大还是过小,都可以按照固定大小显示</li> <li>支持亮度,对比度,饱和度修饰</li> <li>支持头像拍照保存</li> <li>支持php,asp,jsp,asp.net 调用</li> <li>兼容性好,任何浏览器 IE10, IE9, IE8, IE7 IE 6 ,firefox, chrome 都正常使用 </li>

HTML

首先我们在页面上定义了一个隐藏的上传按钮。为什么要隐藏呢?这是为了保证图片成功加载到编辑面板。

<button type="button" id="upload" style="display:none;margin-top:8px;"> 
  swf外定义的上传按钮,点击可执行上传保存操作 
</button>

接着我们要载入jQuery库和flash需要的组件。

<script type="text/javascript" src="jquery.js"></script> 
<script type="text/javascript" src="scripts/swfobject.js"></script> 
<script type="text/javascript" src="scripts/fullAvatarEditor.js"></script>

最后我们看下头像上传的调用方法,说明都已经写在以下代码里。

swfobject.addDomLoadEvent(function() { 
    //以下两行代码正式环境下请删除 
    if (location.href.indexOf('http://') == -1) alert('请于WEB服务器环境中查看、测试!\n\n既 http://*/simpleDemo.html\n\n而不是本地路径 file:///*/simpleDemo.html的方式'); 
    var swf = new fullAvatarEditor("fullAvatarEditor.swf", "expressInstall.swf", "swfContainer", { 
        id: 'swf', 
        upload_url: 'upload.php?userid=999&username=looselive',//上传头像地址和参数 
        method: 'post',//传递到上传接口中的查询参数的提交方式。更改该值时,请注意更改上传接口中的查询参数的接收方式 
        src_upload: 2,//是否上传原图片的选项,有以下值:0-不上传;1-上传;2-显示复选框由用户选择 
        avatar_box_border_width: 0, 
        avatar_sizes: '100*100|50*50|32*32', 
        avatar_sizes_desc: '100*100像素|50*50像素|32*32像素' 
    }, 
    function(msg) { 
        switch (msg.code) { 
        case 1: 
            //alert("页面成功加载了组件!"); 
            break; 
        case 2: 
            //alert("已成功加载图片到编辑面板。"); 
            document.getElementById("upload").style.display = "inline"; 
            break; 
        case 3: 
            if (msg.type == 0) { 
                alert("摄像头已准备就绪且用户已允许使用。"); 
            } else if (msg.type == 1) { 
                alert("摄像头已准备就绪但用户未允许使用!"); 
            } else { 
                alert("摄像头被占用!"); 
            } 
            break; 
        case 5: 
            if (msg.type == 0) { 
                if (msg.content.sourceUrl) { 
                    alert("原图已成功保存至服务器,url为:\n" +  msg.content.sourceUrl + "\n\n" + "头像已成功保存至服务器,url为:\n" + msg.content.avatarUrls.join("\n\n") + "\n\n传递的userid=" + msg.content.userid + "&username=" + msg.content.username); 
                } else { 
                    alert("头像已成功保存至服务器,url为:\n" + msg.content.avatarUrls.join("\n\n") + "\n\n传递的userid=" + msg.content.userid + "&username=" + msg.content.username); 
                } 
            } 
            break; 
        } 
    }); 
    document.getElementById("upload").onclick = function() { 
        swf.call("upload"); 
    }; 
});

PHP

本文以PHP上传为例,我们把头像上传到upload文件夹,并且上传后生成了三张头像缩略图。

$dir = "upload"; 
// 取服务器时间+8位随机码作为部分文件名,确保文件名无重复。 
$filename = date("YmdHis") . '_' . floor(microtime() * 1000) . '_' . createRandomCode(8); 
// 处理原始图片开始------------------------------------------------------------------------> 
//默认的 file 域名称是__source,可在插件配置参数中自定义。参数名:src_field_name 
$source_pic = $_FILES["__source"]; 
//如果在插件中定义可以上传原始图片的话,可在此处理,否则可以忽略。 
if ($source_pic) { 
    if ($source_pic['error'] > 0) { 
        $msg .= $source_pic['error']; 
    } else { 
        //原始图片的文件名,如果是本地或网络图片为原始文件名、如果是摄像头拍照则为 *FromWebcam.jpg 
        $sourceFileName = $source_pic["name"]; 
        //原始文件的扩展名(不包含“.”) 
        $sourceExtendName = substr($sourceFileName, strripos($sourceFileName, ".")); 
        //保存路径 
        $savePath = "$dir\php_source_$filename." . $sourceExtendName; 
        //当前头像基于原图的初始化参数(只有上传原图时才会发送该数据,且发送的方式为POST),用于修改头像时保证界面的视图跟保存头像时一致,提升用户体验度。 
        //修改头像时设置默认加载的原图url为当前原图url+该参数即可,可直接附加到原图url中储存,不影响图片呈现。 
        $init_params = $_POST["__initParams"]; 
        $result['sourceUrl'] = toVirtualPath($savePath) . $init_params; 
        move_uploaded_file($source_pic["tmp_name"], $savePath); 
        $success_num++; 
    } 
}

后台处理缩略图在这里就不细说了,请下载压缩文件查看。有兴趣的朋友可以再看看<a href='http://www.sucaihuo.com/js/3.html' target='_blank'> PHP+jQuery+Ajax多图片上传</a>。

强大的flash头像上传插件(支持旋转、拖拽、剪裁、生成缩略图等)的更多相关文章

  1. php+flash头像上传组件

    有会员系统的站点一般都会有一个头像上传组件,一般做的最简单的是 这样的方式长处是代码写的简单,仅仅要推断图片大小和类型,然后更新数据库.可是用户体验不高.并且站点其它页面假设要使用较小的20X20或1 ...

  2. php头像上传插件

    最近找到了一个比较简单实用的php头像上传插件,兼容IE8及以上等主流浏览器,分享给大家.效果如下: 1.首页效果图:默认显示默认图片. 2.点击图片(拥有裁剪框,可以拖动.缩放.裁剪头像等功能,注意 ...

  3. h5图片上传预览与拖拽上传

    图片上传: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w ...

  4. jQuery文件上传插件jQuery Upload File 有上传进度条

    jQuery文件上传插件jQuery Upload File 有上传进度条 jQuery文件上传插件jQuery Upload File,插件使用简单,支持单文件和多文件上传,支持文件拖拽上传,有进度 ...

  5. Plupload上传插件简单整理

    Plupload Plupload是有TinyMCE的开发者开发的,为您的内容管理系统或是类似上传程序提供一个高度可用的上传插件.Plupload 目前分为一个核心API 和一个jQuery上传队列部 ...

  6. Plupload上传插件中文帮助文档

    Plupload上传插件中文帮助文档 配置参数 实例化一个plupload对象时,也就是 new plupload.Uploader(),需要传入一个对象作为配置参数.后面内容中出现的plupload ...

  7. Plupload上传插件中文文档

    Plupload上传插件中文帮助文档 如有疑问,加群交流:646104701 下载地址:https://www.plupload.com/download/ 配置参数 实例化一个plupload对象时 ...

  8. 可拖拽和带预览图的jQuery文件上传插件ssi-uploader

    插件描述:ssi-uploader是一款带预览图并且可以拖拽文件的jQuery ajax文件上传插件.该文件上传插件支持AJAX,支持多文件上传,可控制上的文件格式和文件大小,提供各种回调函数,使用非 ...

  9. 【React踩坑记四】React项目中引入并使用js-xlsx上传插件(结合antdesign的上传组件)

    最近有一个前端上传并解析excel/csv表格数据的需求. 于是在github上找到一个14K star的前端解析插件 github传送门 官方也有,奈何实在太过于浅薄.于是做了以下整理,避免道友们少 ...

随机推荐

  1. 微信硬件H5面板开发(二) ---- 实现一个灯的控制

    在第一节中讲解了openApi的调用,这一篇讲一下如何实现一个灯的控制.就用微信提供的lamp例子来做,将代码扒下来(实在是没办法,没有示例),整合到自己的项目中.lamp源码:http://file ...

  2. IIS日志-网站运维的好帮手

    对于一个需要长期维护的网站来说,如何让网站长久稳定运行是件很有意义的事情. 有些在开发阶段没有暴露的问题很有可能就在运维阶段出现了,这也是很正常的. 还有些时候,我们希望不断地优化网站,让网站更快速的 ...

  3. ASP.NET MVC Model验证(三)

    ASP.NET MVC Model验证(三) 前言 上篇中说到在MVC框架中默认的Model验证是在哪里验证的,还讲到DefaultModelBinder类型的内部执行的示意图,让大家可以看到默认的M ...

  4. Entity Framework 6 Recipes 2nd Edition(9-2)译->用WCF更新单独分离的实体

    9-2. 用WCF更新单独分离的实体 问题 你想通过WCF为一个数据存储发布查询,插入,删除和修改,并且使这些操作尽可能地简单 此外,你想通过Code First方式实现EF6的数据访问管理 解决方案 ...

  5. node之path模块

    node之path模块 原文链接 //引用该模块 var path = require("path"); 1.路径解析,得到规范化的路径格式 对window系统,目录分隔为'', ...

  6. construction const parameter问题 构造函数const引用参数问题

    工程在window下编译没有任何问题, 但是在linux(CentOS6)下编译就老是报错 C++ 编译器已升级到最新版 6.1.0 错误如下: In file included /bits/stl_ ...

  7. 从Fiddler抓包到Jmeter接口测试(简单的思路)

    备注:本文为博主的同事总结的文章,未经博主允许不得转载. Fiddler下载和配置安装 从网上下载fiddler的安装包即可,直接默认,一直点击下一步,直至安装完成. 安装完成后直接打开Fiddler ...

  8. 使用Google Closure Compiler高级压缩Javascript代码注意的几个地方

    介绍 GCC(Google Closure Compiler)是由谷歌发布的Js代码压缩编译工具.它可以做到分析Js的代码,移除不需要的代码(dead code),并且去重写它,最后再进行压缩. 三种 ...

  9. Linux 解决数量庞大wildfly容器启动与停止的脚本

    一.问题 因公司业务的发展,后台架构的变更,导致测试环境(Linux)部署与管理困难成倍增长,duang的一下,增加N倍.进入正题说问题: 问题1.  测试环境包含普通用户环境.开发者用户环境,原来只 ...

  10. WCF学习系列汇总

    最近在学习WCF,打算把一整个系列的文章都”写“出来,包括理论和实践,这里的“写”是翻译,是国外的大牛写好的,我只是搬运工外加翻译.翻译的不好,大家请指正,谢谢了.如果觉得不错的话,也可以给我点赞,这 ...