[UWP]在應用開發中安全使用文件資源

来源:https://www.cnblogs.com/hhchaos/archive/2018/11/26/10018301.html
-Advertisement-
Play Games

在WPF或者UWP應用開發中,有時候會不可避免的需要操作文件系統(創建文件/目錄),這時候有幾個坑是需要大家註意下的。 創建文件或目錄時的非法字元檢測 在Windows系統中,我們創建文件時會註意到,某些特殊字元是不可以用作文件名輸入的。 那麼,同樣的,如果你的應用可以提供給用戶創建文件/目錄的功能 ...


在WPF或者UWP應用開發中,有時候會不可避免的需要操作文件系統(創建文件/目錄),這時候有幾個坑是需要大家註意下的。

創建文件或目錄時的非法字元檢測

在Windows系統中,我們創建文件時會註意到,某些特殊字元是不可以用作文件名輸入的。

非法文件名

那麼,同樣的,如果你的應用可以提供給用戶創建文件/目錄的功能,要特別註意的是:你必須對用戶鍵入的文件或者目錄名檢測,避免用戶鍵入非法字元。

否則,應用可能會遇到下麵這個bug:System.IO.FileNotFoundException:“文件名、目錄名或捲標語法不正確。”

非法字元異常

避免手段其實也很簡單,System.IO.Path類中可以獲取到所有的非法字元,我們只需要檢測文件或目錄名,避免出現非法字元就可以了。

不可以在文件名中出現的字元 Path.GetInvalidFileNameChars():

char[41] { '"', '<', '>', '|', '\0', '\u0001', '\u0002', '\u0003', '\u0004', '\u0005', '\u0006', '\a', '\b', '\t', '\n', '\v', '\f', '\r', '\u000e', '\u000f', '\u0010', '\u0011', '\u0012', '\u0013', '\u0014', '\u0015', '\u0016', '\u0017', '\u0018', '\u0019', '\u001a', '\u001b', '\u001c', '\u001d', '\u001e', '\u001f', ':', '*', '?', '\\', '/' }

不可以在路徑字元串中出現的字元 Path.GetInvalidPathChars():

char[36] { '"', '<', '>', '|', '\0', '\u0001', '\u0002', '\u0003', '\u0004', '\u0005', '\u0006', '\a', '\b', '\t', '\n', '\v', '\f', '\r', '\u000e', '\u000f', '\u0010', '\u0011', '\u0012', '\u0013', '\u0014', '\u0015', '\u0016', '\u0017', '\u0018', '\u0019', '\u001a', '\u001b', '\u001c', '\u001d', '\u001e', '\u001f' }

這裡給大家提供一個小竅門,使用C#交互視窗(VS2015及更高版本都可以使用),可以快速查看代碼片段執行結果。

C#交互視窗

在XAML中引用外部資源時的非法字元檢測

此外,在開發WPF或者UWP應用時,如果我們需要在XAML中引入外部資源URI,那麼情況會比較特殊一點。

有時候儘管你的文件名或者路徑URI均沒有包含Windows文件系統中的非法字元,應用仍有可能崩潰。這是因為,在XAML中定義了一些不允許出現的字元,這些字元與Windows文件系統中的非法字元不盡相同。

這些字元是:

{ ';' , '/' , '?' , ':' , '@' , '&' , '=' , '+' , '$' , ',','<' , '>' , '#' , '%' , '"' }

例如‘#’,它在文件系統中是合法字元,但是卻不能出現在XAML中引入的外部資源URI字元串里。

這個問題在邵猛大佬的《WPF 圖片顯示中的保留字元問題》中也是有講到的,但是文章中沒有給到解決方法。

在某些情況下,如開發應用時,我們允許用戶上傳圖片到應用文件夾下作為資源使用,我們可以在拷貝資源時通過排除/替換文件名里非法字元的方法來避免這個BUG。

public static class XamlUriHelper
{
    private static readonly char[] Excluded = { ';' , '/' , '?' , ':' , '@' , '&' , '=' , '+' , '$' , ',','<' , '>' , '#' , '%' , '"' };

    public static string GetValidName(string fileName)
    {
        foreach (var item in Excluded)
        {
            fileName = fileName.Replace(item, '_');
        }
        return fileName;
    }
}

結尾

上面說到的兩種情況,第一種是比較好處理的,而第二種需要一些折中的處理手段。另外吐槽一點,XAML應用這麼久了,第二種情況按理說是不應該出現的,不知道微軟方面有沒有註意到(或者說是否有官方解決方法,類似轉義符什麼的?)。如果有瞭解這個問題的大佬,歡迎在評論區指出!

這篇博文到此結束,謝謝大家!


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

-Advertisement-
Play Games
更多相關文章
  • 整理了下阿裡近幾年的java面試題目,大家參考下吧,希望對大家有幫助,可以幫大家查漏補缺。 答對以下這些面試題,可以淘汰掉 80 % 的求職競爭者。 1.hashcode相等兩個類一定相等嗎?equals呢?相反呢? 2.介紹一下集合框架? 3.hashmap hastable 底層實現什麼區別?h ...
  • 1.安裝第三方庫(matplotlib,jieba,wordcloud,numpy) 1.1安裝方法:pip命令線上安裝(python3.x預設安裝了pip,pip下載地址:https://pypi.python.org/pypi/pip#downloads) 已經配置好環境變數前提下,在cmd視窗 ...
  • 一、subprocess 註:如果是Windows,那麼res.stdout.read()讀出的是GBK編碼的信息,在接收端需要用GBK解碼且只能從管道里讀一次結果,PIPE稱為管道。 二、粘包現象 1. TCP會粘包,UDP永遠不會粘包 發送端可以是一K一K地發送數據,而接收端的應用程式可以兩K兩 ...
  • 1. 創建一個Maven的項目,我的項目結構如下: 2. 在pom文件里寫下需要導入的依賴: 3. 在Java文件夾下新建package,在package包下新建介面及其實現類 介面: 實現類: 4. 在resources目錄下新建 文件 我們需要在spring容器的配置文件中進行註冊該Bean s ...
  • 一、MyBatis MyBatis 本是apache的一個開源項目iBatis, 2010年這個項目由apache software foundation 遷移到了google code,並且改名為MyBatis 。2013年11月遷移到Github。 iBATIS一詞來源於“internet”和“ ...
  • 在上一篇文章中,我們介紹了 Python 的函數式編程,現在我們介紹 Python 的類和繼承。 查看上一篇文章請點擊:https://www.cnblogs.com/dustman/p/10010690.html 類先前,我們研究過兩種編程範式--命令式(使用語句、迴圈和函數)和函數(使用純函數、 ...
  • 背景 ​ Spring Cloud現在已經被越來越多的公司採用了,微服務架構比傳統意義上的單服務架構從複雜度上多了很多,出現了很多複雜的場景。比如,我們的產品是個app,支持第三方登錄功能,在手機端調用第三方授權介面之後,返回了用戶的相關信息,比如open_id,性別,頭像等。這些信息我們需要保存在 ...
  • Python基礎知識(13):函數(Ⅳ) Python內置函數 1、abs:取絕對值 2、all:把序列中的每一個元素拿出來做布爾運算,都為真則返回True,如果序列中有None、0、“”、[]、{}、()則返回False 3、any:只要序列中有一個元素做布爾運算後的值為真,就返回True 4、a ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...