之前遇到过很多次要上传类似头像图片这种功能需求,这次是要求弄一个flash插件上传图片

感谢主,一个偶然机会在网上找到了一个很好的腾讯头像修改的flash插件:插件下载

这个功能采用Ajax访问支持,具体实现方法如下:

1.新建一个Ajax.ashx页面,代码如下:

<%@ WebHandler Language="C#" Class="Ajax" %>

using System;
using System.Web;
using System.IO; public class Ajax : IHttpHandler
{ public void ProcessRequest(HttpContext context)
{
string uid = context.Request.QueryString["input"];
if (!string.IsNullOrEmpty(context.Request["Filename"]) && !string.IsNullOrEmpty(context.Request["Upload"]))
{
ResponseText(UploadTempAvatar(uid));
}
if (!string.IsNullOrEmpty(context.Request["avatar1"]) && !string.IsNullOrEmpty(context.Request["avatar2"]) && !string.IsNullOrEmpty(context.Request["avatar3"]))
{
CreateDir(uid);
if (!(SaveAvatar("avatar1", uid) && SaveAvatar("avatar2", uid) && SaveAvatar("avatar3", uid)))
{
File.Delete(GetMapPath("idcardphotos\\upload\\idcardphoto\\" + uid + ".jpg"));
ResponseText("<?xml version=\"1.0\" ?><root><face success=\"0\"/></root>");
return;
}
File.Delete(GetMapPath("idcardphotos\\upload\\idcardphoto\\" + uid + ".jpg"));
ResponseText("<?xml version=\"1.0\" ?><root><face success=\"1\"/></root>");
return;
}
} public bool IsReusable
{
get
{
return false;
}
} private void CreateDir(string uid)
{
string avatarDir = string.Format("idcardphotos/upload/idcardphoto/{0}",
uid);
if (!Directory.Exists(GetMapPath(avatarDir)))
Directory.CreateDirectory(GetMapPath(avatarDir));
} private void ResponseText(string text)
{
HttpContext.Current.Response.Clear();
HttpContext.Current.Response.Write(text);
HttpContext.Current.Response.End();
} private string UploadTempAvatar(string uid)
{
string filename = uid + ".jpg";
string uploadUrl = GetRootUrl("User/idcardphotos/") + "upload/idcardphoto";
string uploadDir = GetMapPath("idcardphotos\\upload\\idcardphoto");
if (!Directory.Exists(uploadDir + "temp\\"))
Directory.CreateDirectory(uploadDir + "temp\\"); filename = "temp/" + filename;
if (HttpContext.Current.Request.Files.Count > )
{
HttpContext.Current.Request.Files[].SaveAs(uploadDir + filename);
} return uploadUrl + filename;
} private byte[] FlashDataDecode(string s)
{
byte[] r = new byte[s.Length / ];
int l = s.Length;
for (int i = ; i < l; i = i + )
{
int k1 = ((int)s[i]) - ;
k1 -= k1 > ? : ;
int k2 = ((int)s[i + ]) - ;
k2 -= k2 > ? : ;
r[i / ] = (byte)(k1 << | k2);
}
return r;
} private bool SaveAvatar(string avatar, string uid)
{
byte[] b = FlashDataDecode(HttpContext.Current.Request[avatar]);
if (b.Length == )
return false;
string size = "";
if (avatar == "avatar1")
size = "large";
else if (avatar == "avatar2")
size = "medium";
else
size = "small";
string avatarFileName = string.Format("idcardphotos/upload/idcardphoto/{0}/{1}.jpg",
uid, size);
FileStream fs = new FileStream(GetMapPath(avatarFileName), FileMode.Create);
fs.Write(b, , b.Length);
fs.Close();
return true;
} public static string GetRootUrl(string forumPath)
{
string ApplicationPath = HttpContext.Current.Request.ApplicationPath != "/" ? HttpContext.Current.Request.ApplicationPath : string.Empty;
int port = HttpContext.Current.Request.Url.Port;
return string.Format("{0}://{1}{2}{3}/{4}",
HttpContext.Current.Request.Url.Scheme,
HttpContext.Current.Request.Url.Host,
(port == || port == ) ? "" : ":" + port,
ApplicationPath,
forumPath);
} public static string GetMapPath(string strPath)
{
if (HttpContext.Current != null)
{
return HttpContext.Current.Server.MapPath(strPath);
}
else //非web程序引用
{
strPath = strPath.Replace("/", "\\");
if (strPath.StartsWith("\\"))
{
strPath = strPath.Substring(strPath.IndexOf('\\', )).TrimStart('\\');
}
return System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, strPath);
}
}
}

选择图片和上传图片时要调用的Ajax处理页面

用来处理选择以及图片编辑完成之后保存到服务器的图片目录下;

2.前台调用flash插件代码:

<script language="javascript" type="text/javascript">
$(function (id) {
var flashParam = '<%=avatarFlashParam %>';
var HeadImg = '<%=this.HeadImg %>';
$("#imgHead").attr("src", HeadImg);
$("#aH").click(function () {
$("#avatarctr1").show();
$("#avatarctr1").html(AC_FL_RunContent('width', '', 'height', '', 'scale', 'exactfit', 'src', flashParam, 'imgHead', 'mycamera', 'name', 'mycamera', 'quality', 'high', 'bgcolor', '#ffffff', 'wmode', 'transparent', 'menu', 'false', 'swLiveConnect', 'true', 'allowScriptAccess', 'always'));
}); return document.getElementById(id);
}); //修改头像
function Upload() {
var imgHead = $("#imgHead").attr("src"); if (null != imgHead && imgHead != "<%=Localhost %>/User/idcardphotos/head.png")
$("#btnUpload").click();
else {
alert("请先上传头像图片!");
return false;
}
} var userAgent = navigator.userAgent.toLowerCase();
var is_opera = userAgent.indexOf('opera') != - && opera.version();
var is_moz = (navigator.product == 'Gecko') && userAgent.substr(userAgent.indexOf('firefox') + , );
var is_ie = (userAgent.indexOf('msie') != - && !is_opera) && userAgent.substr(userAgent.indexOf('msie') + , );
var is_mac = userAgent.indexOf('mac') != -;
function AC_GetArgs(args, classid, mimeType) {
var ret = new Object();
ret.embedAttrs = new Object();
ret.params = new Object();
ret.objAttrs = new Object();
for (var i = ; i < args.length; i = i + ) {
var currArg = args[i].toLowerCase();
switch (currArg) {
case "classid": break;
case "pluginspage": ret.embedAttrs[args[i]] = 'http://www.macromedia.com/go/getflashplayer'; break;
case "src": ret.embedAttrs[args[i]] = args[i + ]; ret.params["movie"] = args[i + ]; break;
case "codebase": ret.objAttrs[args[i]] = 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,0,0'; break;
case "onafterupdate": case "onbeforeupdate": case "onblur": case "oncellchange": case "onclick": case "ondblclick": case "ondrag": case "ondragend":
case "ondragenter": case "ondragleave": case "ondragover": case "ondrop": case "onfinish": case "onfocus": case "onhelp": case "onmousedown":
case "onmouseup": case "onmouseover": case "onmousemove": case "onmouseout": case "onkeypress": case "onkeydown": case "onkeyup": case "onload":
case "onlosecapture": case "onpropertychange": case "onreadystatechange": case "onrowsdelete": case "onrowenter": case "onrowexit": case "onrowsinserted": case "onstart":
case "onscroll": case "onbeforeeditfocus": case "onactivate": case "onbeforedeactivate": case "ondeactivate": case "type":
case "id": ret.objAttrs[args[i]] = args[i + ]; break;
case "width": case "height": case "align": case "vspace": case "hspace": case "class": case "title": case "accesskey": case "name":
case "tabindex": ret.embedAttrs[args[i]] = ret.objAttrs[args[i]] = args[i + ]; break;
default: ret.embedAttrs[args[i]] = ret.params[args[i]] = args[i + ];
}
}
ret.objAttrs["classid"] = classid;
if (mimeType) {
ret.embedAttrs["type"] = mimeType;
}
return ret;
}
function AC_FL_RunContent() {
$("#hid").val("");
var ret = AC_GetArgs(arguments, "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000", "application/x-shockwave-flash");
var str = '';
if (is_ie && !is_opera) {
str += '<object ';
for (var i in ret.objAttrs) {
str += i + '="' + ret.objAttrs[i] + '" ';
}
str += '>';
for (var i in ret.params) {
str += '<param name="' + i + '" value="' + ret.params[i] + '" /> ';
}
str += '</object>';
} else {
str += '<embed ';
for (var i in ret.embedAttrs) {
str += i + '="' + ret.embedAttrs[i] + '" ';
}
str += '></embed>';
}
return str;
}
</script>

加载flash插件的javascript,兼容各主流浏览器

3.前台显示图片修改控件:

<div id="divUnVerify" class="VipVerify_Con VV_rz">
<ul style="height: auto;">
<li class="left">当前头像:</li>
<li class="right" style="height: auto;">
<img id="imgHead" runat="server" />
<a id="aH" href="javascript:;" class="a1">点击更改</a> </li>
<li id="avatarctr1" style="display: none; height: auto;" class="right"></li>
<asp:HiddenField ID="hidH" runat="server"/>
<asp:HiddenField ID="hid" runat="server"/>
</ul>
<script type="text/javascript">
function updateavatar(sender, args) {
$("#imgHead").attr("src", "<%=Localhost %>/User/idcardphotos/upload/idcardphoto/<%=tname %>/medium.jpg?random=1" + Math.random()); $("#hidH").val($("#hid").val() == "" ? '<%=tname %>' : '<%=this.HeadFile %>');
$("#avatarctr1").hide();
}
updateavatar();
</script>
<div class="Sub_but">
<input type="submit" value="确 认" onclick="return Upload();" /> <asp:Button ID="btnUpload"
runat="server" OnClick="btnUpload_Click" Style="display: none;" /></div>
</div>

显示当前头像和修改按钮,用于预览和触发修改图片的操作

4.后台页面加载次绑定并指定Ajax调用目录:

         /// <summary>
/// 绑定身份证上传控件
/// </summary>
public void BindPhotoControl()
{
int port = HttpContext.Current.Request.Url.Port;
string ApplicationPath = HttpContext.Current.Request.ApplicationPath != "/" ? HttpContext.Current.Request.ApplicationPath : string.Empty; tname = DateTime.Now.ToString("yyyyMMddHHmmss") + "H"; Localhost = string.Format("{0}://{1}{2}{3}",
HttpContext.Current.Request.Url.Scheme,
HttpContext.Current.Request.Url.Host,
(port == || port == ) ? "" : ":" + port,
ApplicationPath);
EncodeLocalhost = HttpUtility.UrlEncode(Localhost); avatarFlashParam = string.Format("{0}/User/idcardphotos/common/camera.swf?nt=1&inajax=1&appid=1&input={1}&ucapi={2}/User/Ajax/PhotoAjax.ashx", Localhost, tname, EncodeLocalhost); }

绑定图片上传控件

5.需要前台绑定的属性:

/// <summary>
/// 会员编号
/// </summary>
public int UserID
{
get
{
return int.Parse(Request.QueryString["uid"].ToString());
}
} /// <summary>
/// 会员当前头像详细路径
/// </summary>
public string HeadImg
{
get
{
user.UserID = ;
user.HeadImg = string.Empty;
user = BLL.HSSM_Public_DB.ModelToSqlOne<Model.Users>(user,
string.Format(" UserID={0}", UserID));
return string.IsNullOrEmpty(user.HeadImg) ? (Localhost + "/User/idcardphotos/head.png") : (Localhost + "/User/idcardphotos/upload/idcardphoto/" + user.HeadImg + "/medium.jpg");
}
} /// <summary>
/// 会员当前头像文件夹名
/// </summary>
public string HeadFile
{
get
{
user.UserID = ;
user.HeadImg = string.Empty;
user = BLL.HSSM_Public_DB.ModelToSqlOne<Model.Users>(user,
string.Format(" UserID={0}", UserID));
return user.HeadImg;
}
}

属性,用于前台加载时绑定

6.最终保存图片数据的方法:

 /// <summary>
/// 保存头像
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnUpload_Click(object sender, EventArgs e)
{
user.UserID = ;
user.HeadImg=string.Empty;
user = BLL.HSSM_Public_DB.ModelToSqlOne<Model.Users>(user,
string.Format(" UserID={0}", UserID));
user.HeadImg=hidH.Value.Trim(); int IsSuccess = BLL.HSSM_Public_DB.AlterTable<Model.Users>(user); if (IsSuccess > )
{
string url = "http://" + Request.ServerVariables["HTTP_HOST"] + "/User/UserSetup.aspx?uid=" + UserID;
Response.Redirect(url);//跳转到会员安全认证信息页面
}
else
ClientScript.RegisterStartupScript("".GetType(), "", "<script language=\"javascript\" type=\"text/javascript\">alert('修改失败!');</script>");
}

效果图:

未修改之前的头像:

点击“点击更改”之后弹出图片选择按钮:

选择图片之后进行选择编辑,然后点击“确定”

点击“完成”:

修改成功!

C# Flash 图片上传案例(结合网上腾讯头像上传Flash插件)的更多相关文章

  1. 强大的flash头像上传插件(支持旋转、拖拽、剪裁、生成缩略图等)

    今天介绍的这款flash上传头像功能非常强大,支持php,asp,jsp,asp.net 调用 头像剪裁,预览组件插件. 本组件需要安装Flash Player后才可使用,请从http://dl.pc ...

  2. 【Bootstrap-插件使用】Jcrop+fileinput组合实现头像上传功能

    作者:Dreawer链接:https://zhuanlan.zhihu.com/p/24465742来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 作者:梦游的龙猫(转 ...

  3. [Bootstrap-插件使用]Jcrop+fileinput组合实现头像上传功能

    很久没有更新博客了,再不写点东西都烂了. 这次更新一个小内容,是两个插件的组合使用,实现头像上传功能. 业务需求: 头像上传功能,要对上传的文件进行剪切,且保证头像到服务器时必须是正方形的. 优化&l ...

  4. Django实现注册页面_头像上传

    Django实现注册页面_头像上传 Django实现注册页面_头像上传 1.urls.py 配置路由 from django.conf.urls import url from django.cont ...

  5. FLASH图片上传功能—从百度编辑器UEditor里面提取出来

    为了记录工作中碰到的各种问题,以及学习资料整理,今天开始,将以往的文章进行了一个整理,以后也开始认真的记录学习过程中的各种问题 在HTML里面的文件上传功能一直是个问题,为了实现上传文件大小限制,怎样 ...

  6. php+flash头像上传组件

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

  7. TCP通信---文件上传案例、多线程文件上传

    目前大多数服务器都会提供文件上传的功能,由于文件上传需要数据的安全性和完整性,很明显需要使用TCP协议来实现. TCP通信需要创建一个服务器端程序和一个客户端程序,实现客户端向服务器端上传文件 代码实 ...

  8. PHP 图片上传工具类(支持多文件上传)

    ====================ImageUploadTool======================== <?php class ImageUploadTool { private ...

  9. Html5实现头像上传和编辑,保存为Base64的图片过程

    一.Html5实现头像上传和编辑 插件地址: html5手机端裁剪图片上传头像代码 本地项目引入注意事项: 1.将html的js搬到外面的js文件中,便于管理 2.图片样式在html都是在页面写死,需 ...

随机推荐

  1. ORM Entities vs. Domain Entities under Entity Framework 6.0

    I stumbled upon the following two articles First and Second in which the author states in summary th ...

  2. Windows平台网站图片服务器架构的演进[转]

    构建在Windows平台之上的网站,往往会被业内众多架构师认为很“保守”.很大部分原因,是由于微软技术体系的封闭和部分技术人员的短视造成 的.由于长期缺乏开源支持,所以只能“闭门造车”,这样很容易形成 ...

  3. POJ3349: Snowflake Snow Snowflakes(hash 表)

    考察hash表: 每一个雪花都有各自的6个arm值,如果两个雪花从相同或者不同位置开始顺时针数或者逆时针数可以匹配上,那么这两个雪花就是相等的. 我们采用hash的方法,这样每次查询用时为O(1),总 ...

  4. HDU-1814 Peaceful Commission 2sat

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1814 简单的2sat题. //STATUS:C++_AC_390MS_996KB #include & ...

  5. LLVM在静态分析上的增强 @ WWDC 2013

    在代码还没有真正跑起来的时候,可以利用Clang对代码进行静态分析. 1. 可以应用快捷键Shift+Command+B对项目代码进行分析: 2. 也可以针对某个文件进行分析(现有版本貌似不能针对特定 ...

  6. String的点点滴滴

    一.String 的 equals()到底比较的是什么?equals() 与 == 的区别? 当使用关系运算符==比较两个对象时,是比较两个对象使用的内存地址和内容是否相同,如果两个对象使用的是同一个 ...

  7. powerDesigner的初步使用

    今天初步学习了PowerDesigner,主要学习的内容有以下几个方面: 1.powerDesigner的功能之一是建立一个数据库的关系图,这里选用的数据库是MySql,基本的建立过程是这样的: a. ...

  8. -bash: ls: command not found

    在iMac下ls既然command not found,查找了下 原因:在设置环境变量时,编辑profile文件没有写正确,导致在命令行下 ls等命令不能够识别.解决方案: 直接在控制台下  expo ...

  9. c#问答篇:对象与引用变量-----初学者的困惑

    转自:http://www.cnblogs.com/huangyu/archive/2004/08/02/29622.html 从宏观的角度来看,对象是类的实例.比如: //定义一个名为Someone ...

  10. 选择排序、插入排序、冒泡排序python实现

    选择排序的时间复杂度为O(n^2),是不稳定的排序 冒泡排序的时间复杂度最好情况下为O(n),最坏情况下为O(n^2),平均情况下为O(n^2),是稳定的排序 插入排序的时间复杂度最好情况下为O(n) ...