当前位置:
首页 >
asp.net mvc 从数据库中读取图片的实现代码
发布时间:2025/4/14
54
豆豆
生活随笔
收集整理的这篇文章主要介绍了
asp.net mvc 从数据库中读取图片的实现代码
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
首先是创建一个类,继承于ActionResult,记住要引用System.Web.Mvc命名空间,如下:
public class ImageResult : ActionResult { public ImageFormat ContentType { get; set; } public Image image { get; set; } public string SourceName { get; set; } public ImageResult(string _SourceName, ImageFormat _ContentType) { this.SourceName = _SourceName; this.ContentType = _ContentType; } public ImageResult(Image _ImageBytes, ImageFormat _ContentType) { this.ContentType = _ContentType; this.image = _ImageBytes; } public override void ExecuteResult(ControllerContext context) { context.HttpContext.Response.Clear(); context.HttpContext.Response.Cache.SetCacheability(HttpCacheability.NoCache); if (ContentType.Equals(ImageFormat.Bmp)) context.HttpContext.Response.ContentType = "image/bmp"; if (ContentType.Equals(ImageFormat.Gif)) context.HttpContext.Response.ContentType = "image/gif"; if (ContentType.Equals(ImageFormat.Icon)) context.HttpContext.Response.ContentType = "image/vnd.microsoft.icon"; if (ContentType.Equals(ImageFormat.Jpeg)) context.HttpContext.Response.ContentType = "image/jpeg"; if (ContentType.Equals(ImageFormat.Png)) context.HttpContext.Response.ContentType = "image/png"; if (ContentType.Equals(ImageFormat.Tiff)) context.HttpContext.Response.ContentType = "image/tiff"; if (ContentType.Equals(ImageFormat.Wmf)) context.HttpContext.Response.ContentType = "image/wmf"; if (image != null) { image.Save(context.HttpContext.Response.OutputStream, ContentType); } else { context.HttpContext.Response.TransmitFile(SourceName); } } }然后在 Controller类中创建一个Action.如下:
public ActionResult GetPicture(int id) { ICategory server = new CategoryServer(); byte[] buffer = server.getCategoryPicture(id); if (buffer != null) { MemoryStream stream = new MemoryStream(buffer); System.Drawing.Image image = System.Drawing.Image.FromStream(stream); ImageResult result = new ImageResult(image, System.Drawing.Imaging.ImageFormat.Jpeg); return result; } return View(); }这样就可以显示图片了。
下面几种方法可以显示已经存在的图片
方法一:
方法二:
public ActionResult Image(string id) { var dir = Server.MapPath("/Images"); var path = Path.Combine(dir, id + ".jpg"); return base.File(path, "image/jpg"); }方法三:
[AcceptVerbs(HttpVerbs.Get)] [OutputCache(CacheProfile = "CustomerImages")] public FileResult Show(int customerId, string imageName) { var path = string.Concat(ConfigData.ImagesDirectory, customerId, @"\", imageName); return new FileStreamResult(new FileStream(path, FileMode.Open), "image/jpeg"); }这三种都可以显示已经存在的图片并且我认为第三种方法可以修改为从数据库中读取图片显示。
转载于:https://www.cnblogs.com/hnsongbiao/p/4456999.html
总结
以上是生活随笔为你收集整理的asp.net mvc 从数据库中读取图片的实现代码的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: DataTable / DataSet
- 下一篇: ASP.NET 之异步处理一(Sessi