中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

Asp.net mvc實時生成縮率圖到硬盤
來源:易賢網 閱讀:1214 次 日期:2016-08-09 14:50:03
溫馨提示:易賢網小編為您整理了“Asp.net mvc實時生成縮率圖到硬盤”,方便廣大網友查閱!

這篇文章主要介紹了Asp.net mvc實時生成縮率圖到硬盤的相關資料,需要的朋友可以參考下

對于縮率圖的處理是在圖片上傳到服務器之后,同步生成兩張不同尺寸的縮率供前端調用,剛開始還能滿足需求,慢慢的隨著前端展示的多樣化,縮率圖已不能前端展示的需求,所以考慮做一個實時生成圖片縮率圖服務。

每次調用實時生成縮率圖,不緩存著實有點浪費,所以在生成縮率的同時緩存到硬盤一份,效率提高很多。

之前從網上看了一下有人用nginx + lua實現的,效率那是沒什么可說的,但是時間緊迫,自己也沒時間去研究,所以暫時先用aps.net mvc4來實現 一個,以后有時間了,再慢慢修改。

用自己熟悉的.net性能可能差那么一點點,但是實現速度快,保證可以在極端的時間內上線,并且在功能上更強。

思路很簡單,就是根據請求,判斷需要的縮率圖是否已存在于硬盤上,如果有直接返回,沒有則下載原圖,并生成縮率圖到本地,返回給客戶端。

下面直接粘貼代碼片段:

/// <summary>

 /// 生成圖片縮率圖Action

 /// </summary>

 /// <param name="p">原圖url</param>

 /// <param name="id">圖片尺寸以及生成縮率圖的類型</param>

 /// <returns></returns>

 [ValidateInput(false)]

 public ActionResult Index(string p, string id)

 {

  if (string.IsNullOrEmpty(p))

  {

  return new HttpStatusCodeResult(404);

  }

  string oPath = Regex.Replace(p, @"http[s]?://(.*?)/", "/", RegexOptions.IgnoreCase);

  int? oWidth = 200, oHeight = 200;

  int cutMode = 3;

  string pPath;

  string oDir;

  if (!string.IsNullOrEmpty(id))

  {

  string[] ss = id.Split(new char[] { '_' }, StringSplitOptions.RemoveEmptyEntries);

  if (ss.Length < 2)

  {

   return new HttpStatusCodeResult(404);

  }

  if (ss.Length > 2)

  {

   cutMode = int.Parse(ss[2]);

  }

  oPath = oPath.Insert(oPath.LastIndexOf('/') + 1, string.Format("{0}_{1}_{2}_", ss[0], ss[1], cutMode));

  oWidth = int.Parse(ss[0]);

  oHeight = int.Parse(ss[1]);

  }

  pPath = Server.MapPath(oPath);

  oDir = Path.GetDirectoryName(pPath);

  if (!System.IO.File.Exists(pPath))

  {

  byte[] imagebytes = FileHelper.DownLoadFile(p);

  if (!Directory.Exists(oDir))

  {

   Directory.CreateDirectory(oDir);

  }

  FileHelper.MakeThumbnail(FileHelper.BytToImg(imagebytes), oWidth.Value, oHeight.Value, (ThumbnailMode)cutMode, pPath, true);

  }

  return File(pPath, FileHelper.GetContentTypeByExtension(Path.GetExtension(pPath).ToLower()));

 }

輔助方法:

public class FileHelper

{

 /// <summary>

/// 圖片后綴和ContentType對應字典

/// </summary>

static Dictionary<string, string> extensionContentTypeDic;

static FileHelper()

{

 if (extensionContentTypeDic == null)

 {

 //.jpg", ".png", ".gif", ".jpeg

 extensionContentTypeDic = new Dictionary<string, string>();

 extensionContentTypeDic.Add(".jpg", "image/jpeg");

 extensionContentTypeDic.Add(".png", "image/png");

 extensionContentTypeDic.Add(".gif", "image/gif");

 extensionContentTypeDic.Add(".jpeg", "image/jpeg");

 }

}

/// <summary>

/// 根據后綴名獲取extension

/// </summary>

/// <param name="extension"></param>

/// <returns></returns>

public static string GetContentTypeByExtension(string extension)

{

 if (extensionContentTypeDic.ContainsKey(extension))

 {

 return extensionContentTypeDic[extension];

 }

 return null;

}

/// <summary > 

/// 將Image對象轉化成二進制流 

/// </summary > 

/// <param name="image" > </param > 

/// <returns > </returns > 

public static byte[] ImageToByteArray(Image image)

{

 MemoryStream imageStream = new MemoryStream();

 Bitmap bmp = new Bitmap(image.Width, image.Height);

 Graphics g = Graphics.FromImage(bmp);

 g.DrawImage(image, new System.Drawing.Rectangle(0, 0, image.Width, image.Height));

 try

 {

 bmp.Save(imageStream, image.RawFormat);

 }

 catch (Exception e)

 {

 bmp.Save(imageStream, System.Drawing.Imaging.ImageFormat.Jpeg);

 }

 byte[] byteImg = imageStream.GetBuffer();

 bmp.Dispose();

 g.Dispose();

 imageStream.Close();

 return byteImg;

}

/// <summary> 

/// 字節流轉換成圖片 

/// </summary> 

/// <param name="byt">要轉換的字節流</param> 

/// <returns>轉換得到的Image對象</returns> 

public static Image BytToImg(byte[] byt)

{

 MemoryStream ms = new MemoryStream(byt);

 Image img = Image.FromStream(ms);

 ms.Close();

 return img;

}

/// <summary>

/// 生成縮率圖

/// </summary>

/// <param name="originalImage">原始圖片Image</param>

/// <param name="width">縮率圖寬</param>

/// <param name="height">縮率圖高</param>

/// <param name="mode">生成縮率圖的方式</param>

/// <param name="thumbnailPath">縮率圖存放的地址</param>

public static Image MakeThumbnail(Image originalImage, int width, int height, ThumbnailMode mode, string thumbnailPath, bool isSave = true)

{

 int towidth = width;

 int toheight = height;

 int x = 0;

 int y = 0;

 int ow = originalImage.Width;

 int oh = originalImage.Height;

 switch (mode)

 {

 case ThumbnailMode.HW://指定高寬縮放(可能變形)   

  break;

 case ThumbnailMode.W://指定寬,高按比例   

  toheight = originalImage.Height * width / originalImage.Width;

  break;

 case ThumbnailMode.H://指定高,寬按比例 

  towidth = originalImage.Width * height / originalImage.Height;

  break;

 case ThumbnailMode.Cut://指定高寬裁減(不變形)   

  if ((double)originalImage.Width / (double)originalImage.Height > (double)towidth / (double)toheight)

  {

  oh = originalImage.Height;

  ow = originalImage.Height * towidth / toheight;

  y = 0;

  x = (originalImage.Width - ow) / 2;

  }

  else

  {

  ow = originalImage.Width;

  oh = originalImage.Width * height / towidth;

  x = 0;

  y = (originalImage.Height - oh) / 2;

  }

  break;

 default:

  break;

 }

 //新建一個bmp圖片 

 System.Drawing.Image bitmap = new System.Drawing.Bitmap(towidth, toheight);

 //新建一個畫板 

 Graphics g = System.Drawing.Graphics.FromImage(bitmap);

 //設置高質量插值法 

 g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High;

 //設置高質量,低速度呈現平滑程度 

 g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;

 //清空畫布并以透明背景色填充 

 g.Clear(Color.Transparent);

 //在指定位置并且按指定大小繪制原圖片的指定部分 

 g.DrawImage(originalImage, new Rectangle(0, 0, towidth, toheight),

 new Rectangle(x, y, ow, oh),

 GraphicsUnit.Pixel);

 if (!isSave)

 {

 return bitmap;

 }

 try

 {

 //以jpg格式保存縮略圖 

 //bitmap.Save(thumbnailPath, bitmap.RawFormat);

 bitmap.Save(thumbnailPath, ImageFormat.Jpeg);

 return bitmap;

 }

 catch (System.Exception e)

 {

 throw e;

 }

 finally

 {

 originalImage.Dispose();

 bitmap.Dispose();

 g.Dispose();

 }

 return null;

}

/// <summary>

/// 下載指定文件

/// </summary>

/// <param name="remoteUrl"></param>

/// <param name="ss"></param>

public static byte[] DownLoadFile(string remoteUrl)

{

 WebClient wc = new WebClient();

 try

 {

 return wc.DownloadData(remoteUrl);

 }

 catch (Exception e)

 {

 throw new Exception("下載文件失敗");

 }

}

}

public enum ThumbnailMode

{

/// <summary>

/// 指定高寬縮放(可能變形)

/// </summary>

HW,

/// <summary>

/// 指定高,寬按比例

/// </summary>

H,

/// <summary>

/// 指定寬,高按比例

/// </summary>

W,

/// <summary>

/// 指定高寬裁減(不變形) 

/// </summary>

Cut,

}

訪問方式:

http://www.souji8.com/Home/Index/{width}_{height}_{ThumMode}?p={imageUrl}

{imageUrl}:目標圖片地址

{ThumMode}: 1:指定高寬按比例、2:指定寬,高按比例、3:指定高寬裁減(不變形)

{Width}:期望圖片寬

{Height}:期望圖片高

以上就是本文的全部內容,希望對大家的學習有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:Asp.net mvc實時生成縮率圖到硬盤
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
国产精品自拍三区| 国产精品久久久久久久浪潮网站| 午夜在线电影亚洲一区| 免费成人黄色片| 亚洲电影免费| 欧美精品系列| 99pao成人国产永久免费视频| 麻豆成人小视频| 日韩视频免费观看| 欧美精品一区二区在线观看| 日韩午夜中文字幕| 国产精品av免费在线观看| 在线午夜精品| 国产日韩专区| 欧美精品一区在线| 香港久久久电影| 亚洲激情综合| 国产精品羞羞答答| 免费不卡在线视频| 亚洲一区二区三区四区视频| 国产一区二区三区最好精华液| 久久综合色综合88| 亚洲一区二区三区777| 国产日韩欧美在线看| 欧美日韩精品免费观看| 欧美一区二区精品| 亚洲激情网址| 国产日韩欧美| 欧美视频一区二| 暖暖成人免费视频| 午夜伦欧美伦电影理论片| 亚洲区免费影片| 在线日韩欧美| 狠狠色综合网| 国产精品网站在线观看| 欧美日韩和欧美的一区二区| 美国三级日本三级久久99| 久久成人免费日本黄色| 欧美一进一出视频| 欧美中文在线免费| 欧美一区二区三区喷汁尤物| 国产精品99久久久久久久女警 | 国产亚洲精品美女| 欧美日韩亚洲另类| 欧美日韩精品中文字幕| 99精品热视频只有精品10| 亚洲高清成人| 久久只有精品| 性18欧美另类| 久久国产精品一区二区三区四区| 亚洲欧美一区二区原创| 亚洲免费中文| 欧美在线网址| 麻豆精品网站| 欧美色图五月天| 国产亚洲一区二区在线观看| 影音先锋中文字幕一区| 在线日韩欧美视频| 亚洲视频精品| 久久久噜噜噜久噜久久| 欧美精品在线观看播放| 国产精品美女www爽爽爽| 黑人一区二区三区四区五区| 亚洲人成网站精品片在线观看| 亚洲精品视频在线| 亚洲一区二区高清视频| 久久夜色精品| 国产精品久久久久久模特| 激情久久一区| 久久国产毛片| 欧美午夜精品一区| 亚洲国产欧美一区二区三区久久 | 国产日韩精品入口| 亚洲国产导航| 久久国产精品久久精品国产| 欧美日韩精品欧美日韩精品| 亚洲高清精品中出| 久久久精品一品道一区| 国产精品久久久久久久久久久久久久 | 亚洲高清视频的网址| 午夜在线成人av| 欧美日韩精品欧美日韩精品| 在线观看视频一区二区| 欧美一区二区女人| 国产精品久久久久久亚洲调教| 亚洲黄色成人久久久| 久久香蕉国产线看观看av| 国产午夜精品视频免费不卡69堂| 一区二区三区欧美视频| 欧美日韩国产首页| 亚洲欧洲日夜超级视频| 老**午夜毛片一区二区三区| 亚洲二区在线观看| 亚洲影院在线| 国产色产综合色产在线视频 | 欧美日韩国产综合久久| 亚洲欧洲一区二区天堂久久| 欧美va亚洲va香蕉在线| 亚洲青涩在线| 国产精品一区二区你懂得| 久久国产精品网站| 亚洲精品久久久久久久久| 欧美日韩国产精品成人| 亚洲一区二区三区视频播放| 国产精品男人爽免费视频1| 欧美一区二区精品| 亚洲韩国一区二区三区| 国产精品成人观看视频国产奇米| 欧美在线不卡视频| 亚洲精品日韩久久| 国产午夜精品一区二区三区欧美 | 欧美日韩精品一本二本三本| 亚洲女爱视频在线| 亚洲黄页一区| 狠狠色狠狠色综合人人| 欧美日一区二区在线观看 | 亚洲欧美日韩一区二区| 一区二区在线观看视频在线观看 | 最新日韩在线| 亚洲精选久久| 欧美午夜精品久久久久久超碰| 欧美一级网站| 亚洲午夜精品一区二区三区他趣| 经典三级久久| 国产综合色精品一区二区三区| 欧美亚韩一区| 欧美午夜精品| 欧美视频在线不卡| 欧美伦理影院| 欧美精品三区| 欧美日本韩国| 欧美日韩在线亚洲一区蜜芽| 欧美人成在线| 欧美视频在线视频| 欧美午夜激情小视频| 欧美性大战久久久久| 国产精品国码视频| 国产日韩在线视频| 国内偷自视频区视频综合| 国内成人精品视频| 欧美午夜不卡视频| 欧美破处大片在线视频| 欧美视频在线观看一区| 国产精品乱人伦中文| 国内精品国语自产拍在线观看| 黄色小说综合网站| 尤物yw午夜国产精品视频| 在线播放中文一区| 91久久精品国产91久久性色tv| 亚洲精品女av网站| 亚洲欧美综合网| 免费亚洲婷婷| 欧美四级电影网站| 欧美色中文字幕| 国产午夜精品全部视频在线播放| 国内精品久久久久影院优| 亚洲激情中文1区| 午夜精品福利电影| 欧美激情第3页| 伊人精品在线| 午夜视黄欧洲亚洲| 欧美日韩亚洲91| 1204国产成人精品视频| 亚洲免费成人av电影| 久久久久久成人| 国产视频自拍一区| 亚洲一区二区三区在线看| 免费观看一级特黄欧美大片| 国产精品揄拍一区二区| 夜夜嗨av色一区二区不卡| 久久精品视频免费| 国产欧美亚洲日本| 亚洲直播在线一区| 国产精品三上| 亚洲一区二区在线播放| 欧美香蕉大胸在线视频观看| 99re成人精品视频| 欧美乱大交xxxxx| 99精品久久久| 欧美日韩免费高清一区色橹橹| 亚洲免费av片| 欧美午夜影院| 午夜精品在线看| 国产一级一区二区| 久久久噜久噜久久综合| 国产伦精品一区二区三区高清| 日韩一区二区高清| 欧美精品在线观看一区二区| 日韩视频不卡中文| 欧美视频精品在线观看| 一区二区三区波多野结衣在线观看| 久久激情视频久久| 日韩一级视频免费观看在线| 欧美成人有码| 国产一区二区三区最好精华液| 欧美综合国产| 国产一区二区剧情av在线| 嫩草国产精品入口| 亚洲伦理在线免费看| 国产精品分类|