在客戶端展示本地圖片

来源:http://www.cnblogs.com/Joker37/archive/2017/08/07/7297773.html
-Advertisement-
Play Games

當用戶在客戶端上請求本地圖片的時候,我們需要把本地的圖片展示。 1.在控制器端把圖片轉換成流的形式 2.前臺請求控制器端的方法,輸出圖片 控制器端: public class ImageController : Controller { private static readonly string ...


當用戶在客戶端上請求本地圖片的時候,我們需要把本地的圖片展示。

1.在控制器端把圖片轉換成流的形式

2.前臺請求控制器端的方法,輸出圖片

控制器端:

 public class ImageController : Controller {
        private static readonly string PATH = @"C:\Users\xiechongxi\Desktop\";
        //這個key就是圖片的名字和尾碼名
        public ActionResult GetImage(string key) {
            //path就包含了路徑和文件名,尾碼
            string path = Path.Combine(PATH, key);
            //ext是用GetExtension方法獲取路徑的尾碼名
            string ext = System.IO.Path.GetExtension(path);
            //判斷這個路徑是否有圖片
            if (System.IO.File.Exists(path)) {
                //通過http返回一個image類型的文件
                using (FileStream fs = System.IO.File.OpenRead(path)) {
                    return File(StreamToBytes(fs), "image/" + ext);
                }
            }
            else {
                return null;
            }
        }

        private byte[] StreamToBytes(Stream stream) {
            byte[] bytes = new byte[stream.Length];
            stream.Read(bytes, 0, bytes.Length);
            // 設置當前流的位置為流的開始
            stream.Seek(0, SeekOrigin.Begin);
            return bytes;
        }
    }
Cotroller

前臺獲取:

//image表示的是ImageCotroller,@scene.LocalKey表示的是文件名,包含尾碼名
<img src="/image/@scene.LocalKey"/>
Html

是不是感覺Html裡面很奇怪,<img src="/image/40ed9c2c-1d1c-470c-a760-7f860e9c309c.jpg">這種形式

實際上為了美觀更改了路由,可以參考一下以下路由設置

public static void RegisterRoutes(RouteCollection routes) {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

            routes.MapRoute(
                "Image",//路由名稱
                "Image/{key}",
                new { controller = "Image", action = "GetImage" }
            );

            routes.MapRoute(
                "Default", // 路由名稱
                "{controller}/{action}/{id}", // 帶有參數的 URL
                new { controller = "Follow", action = "Index", id = UrlParameter.Optional } // 參數預設值
            );

        }
路由設置

新添加的路由一定要放在預設路由上面,這裡有個優先順序,我也就不多說。

 

流程是這樣的img標簽裡面的src後面這個地址,是請求ImageCotroller中的GetImage方法(路由設置效果),並且傳遞參數(文件名和尾碼),然後GetImage返回的是文件。

 

 


註:此篇隨筆只供參考使用,而且也有很多小瑕疵,最主要的不是代碼,邏輯才是最重要的。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文將在asp.net core api 項目中使用efcore corefirst模式 簡單配置鏈接sqlserver資料庫,以及簡單的資料庫遷移操作 一 新建項目 1. 首先我們先用vs2017 創建一個空的 asp.net core api 項目 2. 在生成的解決方案下在建立一個訪問資料庫使 ...
  • string轉byte[]:byte[] byteArray = System.Text.Encoding.Default.GetBytes ( str ); byte[]轉string:string str = System.Text.Encoding.Default.GetString ( by ...
  • 下載地址:https://www.microsoft.com/en-gb/download/details.aspx?id=7211 1.啟動IIS管理器,然後點擊左側的伺服器名稱,(註意:不要點擊網站下的站點或虛擬目錄,否則找不到下麵的” Enable Advanced Logging”); 2. ...
  • 創建始終為最新狀態、具有吸引力的互動式報告 Power BI Embedded 使你可以針對 Power BI Desktop 中的應用程式數據創建有影響力的互動式數據可視化,而無需編寫任何代碼。通過形式自由的拖放式畫布輕鬆瀏覽你的應用程式數據,並使用公式和關係式生產豐富的數據模型。直接從各種新式 ...
  • 對於在Linux上開發.Net Core的程式員來說, 似乎都缺少一個好的IDE. Windows上有Visual Studio, Mac上有Visual Studio for Mac, 難道Linux只有Visual Studio Code了嗎? Linux上有兩個最好的編輯器: VIM和Emac ...
  • 緩存可以大大提高應用程式載入時間和響應速度。我們可以使用緩存Tag Helpers緩存不會頻繁更改的HTML內容。 ...
  • 在前面的隨筆,我介紹了Bootstrap-table表格插件的具體項目應用過程,本篇隨筆介紹另外一個Bootstrap FieInput插件的使用,整合兩者可以實現我們常規的Web數據導入操作,導入數據操作過程包括有上傳文件,預覽數據,選擇並提交記錄等一系列操作。關於這個插件,我在早期隨筆《Boot... ...
  • .NET 微服務:適用於容器化 .NET 應用的體繫結構 容器和 Docker 簡介 什麼是 Docker? Docker 術語 Docker 容器、映像和註冊表 為 Docker 容器選擇 .NET Core 還是 .NET Framework 通用指南 何時為 Docker 容器選擇 .NET ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...