C# Flash 图片上传案例(结合网上腾讯头像上传Flash插件)
之前遇到过很多次要上传类似头像图片这种功能需求,这次是要求弄一个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插件)的更多相关文章
- 强大的flash头像上传插件(支持旋转、拖拽、剪裁、生成缩略图等)
今天介绍的这款flash上传头像功能非常强大,支持php,asp,jsp,asp.net 调用 头像剪裁,预览组件插件. 本组件需要安装Flash Player后才可使用,请从http://dl.pc ...
- 【Bootstrap-插件使用】Jcrop+fileinput组合实现头像上传功能
作者:Dreawer链接:https://zhuanlan.zhihu.com/p/24465742来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 作者:梦游的龙猫(转 ...
- [Bootstrap-插件使用]Jcrop+fileinput组合实现头像上传功能
很久没有更新博客了,再不写点东西都烂了. 这次更新一个小内容,是两个插件的组合使用,实现头像上传功能. 业务需求: 头像上传功能,要对上传的文件进行剪切,且保证头像到服务器时必须是正方形的. 优化&l ...
- Django实现注册页面_头像上传
Django实现注册页面_头像上传 Django实现注册页面_头像上传 1.urls.py 配置路由 from django.conf.urls import url from django.cont ...
- FLASH图片上传功能—从百度编辑器UEditor里面提取出来
为了记录工作中碰到的各种问题,以及学习资料整理,今天开始,将以往的文章进行了一个整理,以后也开始认真的记录学习过程中的各种问题 在HTML里面的文件上传功能一直是个问题,为了实现上传文件大小限制,怎样 ...
- php+flash头像上传组件
有会员系统的站点一般都会有一个头像上传组件,一般做的最简单的是 这样的方式长处是代码写的简单,仅仅要推断图片大小和类型,然后更新数据库.可是用户体验不高.并且站点其它页面假设要使用较小的20X20或1 ...
- TCP通信---文件上传案例、多线程文件上传
目前大多数服务器都会提供文件上传的功能,由于文件上传需要数据的安全性和完整性,很明显需要使用TCP协议来实现. TCP通信需要创建一个服务器端程序和一个客户端程序,实现客户端向服务器端上传文件 代码实 ...
- PHP 图片上传工具类(支持多文件上传)
====================ImageUploadTool======================== <?php class ImageUploadTool { private ...
- Html5实现头像上传和编辑,保存为Base64的图片过程
一.Html5实现头像上传和编辑 插件地址: html5手机端裁剪图片上传头像代码 本地项目引入注意事项: 1.将html的js搬到外面的js文件中,便于管理 2.图片样式在html都是在页面写死,需 ...
随机推荐
- 关于VNC黑屏的问题
注意: 1.vncserver启动后生成的ID号(1,2,3)要和VNCview里面填入的 ip:ID要保持一致 不然看到的就是黑屏 比如:vncserver启动后 产生: localhost.lo ...
- 【解决】python2.x版本的Django下admin管理页面css无效
折腾一下午,终于解决了这个问题,有必要记录一下,我就奇怪了为什么实验室电脑没问题,到宿舍就挂掉了,哼 主要是改mimetypes文件,位于D:\MySoftware\Python27\Lib下 1.添 ...
- about云开发虚拟化资源汇总,持续更新
H3C实验手册H3C实验手册内容包括:1.帧中继典型配置举例一2.典型访问列表和地址转换综合应用配置案例3.交换机基本配置4.轮循DCC配置举例5.X.25典型配置举例6.MultiLink PPP配 ...
- poj 2367 Genealogical tree (拓扑排序)
火星人的血缘关系很奇怪,一个人可以有很多父亲,当然一个人也可以有很多孩子.有些时候分不清辈分会产生一些尴尬.所以写个程序来让n个人排序,长辈排在晚辈前面. 输入:N 代表n个人 1~n 接下来n行 第 ...
- jenkins持续集成配置备忘
配过好几次,但是老忘记.记录备忘. 安装下列插件: ssh和git插件用来下载源码 publish over ssh 插件用来发布代码到测试环境. email插件用来更强大的email配置. file ...
- Block介绍(二)内存管理与其他特性
我们在前一章介绍了block的用法,而正确使用block必须要求正确理解block的内存管理问题.这一章,我们只陈述结果而不追寻原因,我们将在下一章深入其原因. 一.block放在哪里 我们针对不同情 ...
- position与anchorPoint
相信初接触到CALayer的人都会遇到以下几个问题: 为什么修改anchorPoint会移动layer的位置?CALayer的position点是哪一点呢?anchorPoint与position有什 ...
- php静态方法与非静态方法在性能上有什么区别?
先贴代码如下: class class1 { public static function test(){} } class class2 { public function test(){} } v ...
- Linux为Tomecat指定JDK
在搭建Jenkin+Sonar集成时,由于系统环境配置了jdk1.7,但是jenkins在安装sonar的插件时,需要jdk1.8.,所以需要在Tomcat指定jdk1.8. (1)暂停Tomcat ...
- SQL 左外连接,右外连接,全连接,内连接
原文地址 连接条件可在FROM或WHERE子句中指定,建议在FROM子句中指定连接条件.WHERE和HAVING子句也可以包含搜索条件,以进一步筛选连接条件所选的行. 连接可 ...