刚刚做了个文件上传功能,拿来分享一下!(MVC架构及传统架构通用)
文件上传无论在软件还是在网站上都十分常见,我今天再把它拿出来,讲一下,主要讲一下它的设计思想和实现技术,为了它的通用性,我把它做在了WEB.Service项目里,即它是针对服务器的,它的结构是关联UI(WEB)层与Service层(BLL)的桥梁.
结构
上传基类:
上传文件的接口规范:
接口的实现:
UI层调用WEB.Service层的上传功能:(附代码)

public class FileUploadController : Controller { WEB.Services.IFileUpload iFileUpload = null; public FileUploadController() { iFileUpload = new WEB.Services.FileUpload(); } #region 文件上传 public ActionResult uploadheadpic() { return View(); } [HttpPost] public ActionResult uploadheadpic(FormCollection formcollection) { if (Request.Files.Count > 0) { HttpPostedFileBase file = Request.Files[0]; Entity.Commons.VMessage vm = iFileUpload.Image(WEB.Services.UpLoadType.DownloadUrl, file); if (vm.IsComplete) TempData["PicUrl"] = "{result:true,msg:\"" + vm[0].Replace("\"", "") + "\"}"; else TempData["PicUrl"] = "{result:false,msg:\"" + vm[0].Replace("\"", "") + "\"}"; } return View(); } #endregion }

下面公布一下上传的基类代码:(如果有设计不合理的地方,欢迎大家留言)

namespace WEB.Services { #region 所需枚举 /// <summary> /// 文件上传类型 /// </summary> public enum UpLoadType { /// <summary> /// 下载地址 /// </summary> DownloadUrl = 0, /// <summary> /// 文件地址 /// </summary> FileUrl = 1, } /// <summary> /// 上传错误信息列举 /// </summary> public enum WarnEnum { ImgContentType, ImgContentLength, ImgExtension, } #endregion #region 文件上传基本服务类 /// <summary> /// 文件上传基本服务类 /// </summary> public abstract class FileUploadBase { /// <summary> /// 图片MIME /// </summary> protected static List<string> imgMIME = new List<string> { "application/x-zip-compressed", "application/octet-stream", "application/x-compressed", "application/x-rar-compressed", "application/zip", "application/vnd.ms-excel", "application/vnd.ms-powerpoint", "application/msword", "image/jpeg", "image/gif", "audio/x-mpeg", "audio/x-wma", "application/x-shockwave-flash", "video/x-ms-wmv", "application/vnd.openxmlformats-officedocument.wordprocessingml.document", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", "application/vnd.openxmlformats-officedocument.presentationml.presentation", }; /// <summary> /// 验证消息字典 /// </summary> protected static Dictionary<WarnEnum, string> msgDIC = new Dictionary<WarnEnum, string> { {WarnEnum.ImgContentType ,"只能上传指定类型的文件!" }, {WarnEnum.ImgContentLength ,"只能上传文件大小为{0}以下!" }, {WarnEnum.ImgExtension , "文件的扩展文件不正确"} }; /// <summary> /// 相对地址字典 /// </summary> protected static Dictionary<UpLoadType, string> relativePathDic = new Dictionary<UpLoadType, string> { {UpLoadType.DownloadUrl ,@"DownLoad/" }, {UpLoadType.FileUrl ,@"FileUpload/" }, }; /// <summary> /// 图片后缀 /// </summary> protected static string[] imgExtension = { "xls", "doc", "zip", "rar", "ppt", "docx", "xlsx", "pptx", "mp3", "wma", "swf", "jpg", "jpeg", "gif" }; } #endregion }

文件上传实现类:

public class FileUpload : FileUploadBase, IFileUpload { #region 文件上级WWW服务器及图像服务器 public Entity.Commons.VMessage Image(UpLoadType type, HttpPostedFileBase hpf) { HttpRequest Request = HttpContext.Current.Request; Entity.Commons.VMessage vmsg = new Entity.Commons.VMessage(); if (this.IsIamgeVaild(type, hpf)) { string relativePath = string.Format(VConfig.BaseConfigers.LocationUploadPath, relativePathDic[type]); string path = HttpContext.Current.Server.MapPath(relativePath); #region 建立路径 DirectoryInfo di = new DirectoryInfo(path); if (!di.Exists) { di.Create(); } #endregion string guid = Guid.NewGuid().ToString(); string fileName = string.Format("{0}{1}", guid, new FileInfo(hpf.FileName).Extension);//上传文件的名称 hpf.SaveAs(string.Format("{0}{1}", path, fileName)); vmsg.Clear(); vmsg.AddItem(string.Format("{0}://{1}{2}{3}", Request.Url.Scheme, Request.Url.Authority, relativePath.Replace('\\', '/'), fileName ) ); vmsg.AddItem(guid); vmsg.IsComplete = true; } else { vmsg.AddItemRange(this.GetRuleViolations(type, hpf)); vmsg.IsComplete = false; } return vmsg; } public Entity.Commons.VMessage ImageToServer(string url) { Entity.Commons.VMessage vmsg = new Entity.Commons.VMessage(); Uri uri = new Uri(url); string fileName = uri.Segments[uri.Segments.Length - 1]; string typeStr = uri.Segments[uri.Segments.Length - 2]; VCommons.Utils.FileUpLoad( string.Format(BaseConfigers.DefaultUploadUri, typeStr.TrimEnd('/')), HttpContext.Current.Server.MapPath(uri.LocalPath) ); vmsg.IsComplete = true; vmsg.AddItem( string.Format("{0}://{1}/upload/{2}{3}", HttpContext.Current.Request.Url.Scheme, BaseConfigers.ImageServerHost, typeStr, fileName ) ); return vmsg; } #endregion #region 验证文件 internal bool IsIamgeVaild(UpLoadType type, HttpPostedFileBase hpf) { return this.GetRuleViolations(type, hpf).Count() == 0; } /// <summary> /// 验证文件 /// </summary> /// <param name="hpf"></param> /// <returns></returns> internal IEnumerable<string> GetRuleViolations(UpLoadType type, HttpPostedFileBase hpf) { if (!imgMIME.Contains(hpf.ContentType))// MIME yield return msgDIC[WarnEnum.ImgContentType]; int contentLength = this.GetContentLengthByType(type);//文件大小 if (hpf.ContentLength > contentLength) yield return string.Format(msgDIC[WarnEnum.ImgContentLength], contentLength / 1024); if (!imgExtension.Contains(hpf.FileName.Substring(hpf.FileName.LastIndexOf('.') + 1)))//文件后缀 yield return msgDIC[WarnEnum.ImgExtension]; yield break; } #endregion #region 根据 FileUpLoadContentLengthType 类型 获取相应的大小 /// <summary> /// 根据 FileUpLoadContentLengthType 类型 获取相应的大小 /// </summary> /// <param name="type">文件上传大小枚举值</param> /// <returns>返回</returns> int GetContentLengthByType(UpLoadType type) { switch (type) { case UpLoadType.DownloadUrl: return 200000; //200M case UpLoadType.FileUrl: return 200000; default: throw new Exception("可能有错误"); } } #endregion }
刚刚做了个文件上传功能,拿来分享一下!(MVC架构及传统架构通用)的更多相关文章
- MVC5:使用Ajax和HTML5实现文件上传功能
引言 在实际编程中,经常遇到实现文件上传并显示上传进度的功能,基于此目的,本文就为大家介绍不使用flash 或任何上传文件的插件来实现带有进度显示的文件上传功能. 基本功能:实现带有进度条的文件上传功 ...
- Spring 文件上传功能
本篇文章,我们要来做一个Spring的文件上传功能: 1. 创建一个Maven的web工程,然后配置pom.xml文件,增加依赖: <dependency> <groupId> ...
- Spring +SpringMVC 实现文件上传功能。。。
要实现Spring +SpringMVC 实现文件上传功能. 第一步:下载 第二步: 新建一个web项目导入Spring 和SpringMVC的jar包(在MyEclipse里有自动生成spring ...
- 用c++开发基于tcp协议的文件上传功能
用c++开发基于tcp协议的文件上传功能 2005我正在一家游戏公司做程序员,当时一直在看<Windows网络编程> 这本书,把里面提到的每种IO模型都试了一次,强烈推荐学习网络编程的同学 ...
- nodejs 实现简单的文件上传功能
首先需要大家看一下目录结构,然后开始一点开始我们的小demo. 文件上传总计分为三种方式: 1.通过flash,activeX等第三方插件实现文件上传功能. 2.通过html的form标签实现文件上传 ...
- Android 实现文件上传功能(upload)
文 件上传在B/S应用中是一种十分常见的功能,那么在Android平台下是否可以实现像B/S那样的文件上传功能呢?答案是肯定的.下面是一个模拟网站程 序上传文件的例子.这里只写出了Android部分的 ...
- Springboot如何启用文件上传功能
网上的文章在写 "springboot文件上传" 时,都让你加上模版引擎,我只想说,我用不上,加模版引擎,你是觉得我脑子坏了,还是觉得我拿不动刀了. springboot如何启用文 ...
- PHPCMS_V9 模型字段添加单文件上传功能
后台有“多文件上传”功能,但是对于有些情况,我们只需要上传一个文件,而使用多文件上传功能上传一个文件,而调用时调用一个文件URL太麻烦了. 使用说明: 1.打开phpcms\modules\conte ...
- 配置php.ini实现PHP文件上传功能
本文介绍了如何配置php.ini实现PHP文件上传功能.其中涉及到php.ini配置文件中的upload_tmp_dir.upload_max_filesize.post_max_size等选项,这些 ...
随机推荐
- Python_编程题集_002_菱形
2.编写程序实现: n=5,输出: * *** ***** *** * n=6,输出: * *** ***** ***** *** * n为任意大于1的正整数. 解: #思路: # 第一步:判断行数, ...
- 关于react-native引入第三方库,运行react-native link xxxxx后项目无法运行
最新版本的react-native中,官方表示将要移除 AsyncStorage,推荐使用@react-native-community/async-storage,好吧官方经常这么干 按照官方提 ...
- 【笔记】ubuntu如何切换到root用户&&linux如何关闭各种保护
默认安装完成之后并不知道root用户的密码,那么如何应用root权限呢? (1)sudo 命令 这样输入当前管理员用户密码就可以得到超级用户的权限.但默认的情况下5分钟root权限就失效了. () ...
- SpringMVC最核心
如图所示:
- nginx启动、重启、关闭、升级
一.启动 cd usr/local/nginx/sbin ./nginx 二.重启 更改配置重启nginx kill -HUP 主进程号或进程号文件路径 或者使用 cd /usr/local/ngin ...
- 03003_Http响应
1.Http协议 (1)状态码: (2)常用的状态码如下: 200 :请求成功: 302 :请求重定向: 304 :请求资源没有改变,访问本地缓存: 404 :请求资源不存在.通常是用户路径编写错误, ...
- iOS第三方语音-微信语音
网址链接:http://pr.weixin.qq.com/ 里面包含了微信语音和图像,集成很简单,下载方demo后会有个文档,按照流程来(因为它只提供了真机的.a文件,所以只能用真机哦,不然会报错) ...
- hdu 2579
#include<stdio.h> #include<queue> #include<iostream> #include<string.h> #inc ...
- bzoj3875 【Ahoi2014】骑士游戏 spfa处理后效性动规
骑士游戏 [故事背景] 长期的宅男生活中,JYY又挖掘出了一款RPG游戏.在这个游戏中JYY会 扮演一个英勇的骑士,用他手中的长剑去杀死入侵村庄的怪兽. [问题描述] 在这个游戏中,JYY一共有两种攻 ...
- 外星联络(bzoj 2251)
Description 小 P 在看过电影<超时空接触>(Contact)之后被深深的打动,决心致力于寻找外星人的事业.于是,他每天晚上都爬在屋顶上试图用自己的收音机收听外星人发来的信息. ...