在好例子网,分享、交流、成长!
您当前所在位置:首页js 开发实例Ajax框架/RIA → 富客户端上传头像编辑组件

富客户端上传头像编辑组件

Ajax框架/RIA

下载此实例
  • 开发语言:js
  • 实例大小:0.23M
  • 下载次数:19
  • 浏览次数:237
  • 发布时间:2016-01-15
  • 实例类别:Ajax框架/RIA
  • 发 布 人:35109708
  • 文件格式:.zip
  • 所需积分:1
 相关标签: 上传 组件 头像

实例介绍

【实例简介】

富客户端上传头像编辑组件

【实例截图】

【核心代码】


using System;
using System.Collections;
using System.Collections.Generic;
using System.Drawing;
using System.Drawing.Imaging;
using System.IO;
using System.Text;
using System.Text.RegularExpressions;
using System.Web;
using Newtonsoft.Json;
/*
温馨提示:
	在flash的参数名upload_url中可自行定义一些参数(请求方式:GET),定义后在服务器端获取即可,比如可以应用到用户验证,文件的保存名等。
	本示例未作极致的用户体验与严谨的安全设计(如用户直接访问此页时该如何,万一客户端数据不可信时验证文件的大小、类型等),只保证正常情况下无误,请阁下注意。
*/
public partial class Upload : System.Web.UI.Page
{
	protected void Page_Load(object sender, EventArgs e)
	{
		Result result = new Result();
		result.avatarUrls = new ArrayList();
		result.success = false;
		result.msg = "Failure!";
		//取服务器时间 8位随机码作为部分文件名,确保文件名无重复。
		string fileName = DateTime.Now.ToString("yyyyMMddhhmmssff")   CreateRandomCode(8);
		//定义一个变量用以储存当前头像的序号
		int avatarNumber = 1;
		//遍历所有文件域
		foreach(string fieldName in Request.Files.AllKeys)
		{
			HttpPostedFile file = Request.Files[fieldName];
			//原始图片(file 域的名称:__source,如果客户端定义可以上传的话,可在此处理)。
			if(fieldName == "__source")
			{
				//文件名,如果是本地或网络图片为原始文件名(不含扩展名)、如果是摄像头拍照则为 *FromWebcam
				//fileName = file.FileName;
				//当前头像基于原图的初始化参数(即只有上传原图时才会发送该数据),用于修改头像时保证界面的视图跟保存头像时一致,提升用户体验度。
				//修改头像时设置默认加载的原图url为当前原图url 该参数即可,可直接附加到原图url中储存,不影响图片呈现。
				string initParams = Request.Form["__initParams"];
				result.sourceUrl = string.Format("upload/csharp_source_{0}.jpg", fileName);
				file.SaveAs(Server.MapPath(result.sourceUrl));
				result.sourceUrl  = initParams;
			}
			//头像图片(file 域的名称:__avatar1,2,3...)。
			else
			{
				string virtualPath = string.Format("upload/csharp_avatar{0}_{1}.jpg", avatarNumber, fileName);
				result.avatarUrls.Add(virtualPath);
				file.SaveAs(Server.MapPath(virtualPath));
				avatarNumber  ;
			}
		}
		result.success = true;
		result.msg = "Success!";
		//返回图片的保存结果(返回内容为json字符串,可自行构造,该处使用Newtonsoft.Json构造)
		Response.Write(JsonConvert.SerializeObject(result));
	}
	/// <summary>
	/// 生成指定长度的随机码。
	/// </summary>
	private string CreateRandomCode(int length)
	{
		string [] codes = new string [36] { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z" };
		StringBuilder randomCode = new StringBuilder();
		Random rand = new Random();
		for ( int i =0; i < length; i   )
		{
			randomCode.Append(codes [rand.Next(codes.Length)]);
		}
		return randomCode.ToString();
	}
	/// <summary>
	/// 表示图片的上传结果。
	/// </summary>
	private struct Result
	{
		/// <summary>
		/// 表示图片是否已上传成功。
		/// </summary>
		public bool success;
		/// <summary>
		/// 自定义的附加消息。
		/// </summary>
		public string msg;
		/// <summary>
		/// 表示原始图片的保存地址。
		/// </summary>
		public string sourceUrl;
		/// <summary>
		/// 表示所有头像图片的保存地址,该变量为一个数组。
		/// </summary>
		public ArrayList avatarUrls;
	}
}

标签: 上传 组件 头像

实例下载地址

富客户端上传头像编辑组件

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警