ASP.NET誤人子弟教程:在MVC下如何返回圖片


這幾天忙着一些小事,也沒有寫什么了,今天,我們來玩一個比較簡單的東東。就是在MVC下如何返回圖片,相信,在傳統WebForm下,大家都曉得怎么弄,方也不限於一種,但是,在架構較為嚴格的MVC里面,剛開始接觸的朋友,可能不太清楚如何實現。

 

首先,我們應當從控制器入手,昨天有位朋友問我,控制器一般不都是return View的嗎?那怎么返回圖片? 當然,Controller類也沒有return Image 的,上次我們的例子是返回JSON,其實我們可以讓其返回一個文件流,一開始我也想過使用ViewData,但這個在視圖頁面上只能通過服務器端代碼來操作,如果希望用JS,就不那么好辦了。

 

Controller類有一個File方法,當然,它有N個重載,而且返回的對象不一樣,這里我們要找到返回FileContentResult類型的File方法,因為,我測試過,在<img>元素中,src屬性不能讀取到FileStreamResult對象的內容,是空白的,所以,不能返回FileStreamResult來獲取。

 

請參考下面代碼,不復雜,我先畫一個矩形,然后在矩形上畫一些文字,然后返回。

  1. public ActionResult GetImg()  
  2. {  
  3.     Bitmap bmp = new Bitmap(100, 35);  
  4.     Graphics g = Graphics.FromImage(bmp);  
  5.     g.Clear(Color.White);  
  6.     g.FillRectangle(Brushes.Red, 2, 2, 65, 31);  
  7.     g.DrawString("學習MVC", new Font("黑體", 15f), Brushes.Yellow, new PointF(5f, 5f));  
  8.     MemoryStream ms = new MemoryStream();  
  9.     bmp.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);  
  10.     g.Dispose();  
  11.     bmp.Dispose();  
  12.     return File(ms.ToArray(), "image/jpeg");  
  13. }  

 

注意,這個方法定義在你的控制器中,屬於一個Action。

在前台頁面,我們這樣處理。

  1. <div>  
  2.     <img src="/Home/GetImg" width="100" alt="" />  
  3. </div>  

這樣,我們就可以在需要的時候通過JS來操作了,比如,返回隨機圖片,或者驗證碼什么的。


 


 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM