在我們Winform開發中,往往需要涉及到附件的統一管理,因此我傾向於把它們獨立出來作為一個附件管理模塊,這樣各個模塊都可以使用這個附件管理模塊,更好的實現模塊重用的目的。在涉及附件管理的場景中,一個數據記錄可能對應多個附件組場景,每個附件組則涉及附件多個文件,往往這些附件可能放置的目錄會有所不同,... ...
在我們Winform開發中,往往需要涉及到附件的統一管理,因此我傾向於把它們獨立出來作為一個附件管理模塊,這樣各個模塊都可以使用這個附件管理模塊,更好的實現模塊重用的目的。在涉及附件管理的場景中,一個數據記錄可能對應多個附件組場景,每個附件組則涉及附件多個文件,往往這些附件可能放置的目錄會有所不同,導致如果對文件備份管理不是很方便。本篇隨筆主要基於這個考慮,對附件文件進行一個集中歸檔的處理,以便把散落在各個地方的附件集中放置在我們制定的歸檔目錄中,而且並不影響已有附件的關聯顯示。
1、附件的界面管理
我們在做數據記錄存儲的時候,一個記錄可能需要存儲多個場景下的附件信息,這些維護查看附件的界面可以做成相對比較統一的控制項方式進行展示,這樣我們使用起來就比較省事一些。
樣在項目中集成(如數據編輯視窗),直接拖動這個控制項到界面中,運行就可以看到下麵的效果了。
在實際的項目中,如客戶信息,病人信息等記錄,可能對應多個附件記錄,那麼我們把它們分組進行管理即可。
附件管理在很多信息化管理系統中很普遍使用,例如我在病人管理系統界面裡面,可以在一個界面裡面分門別類管理很多影像學的圖片資料,通過查看附件,可以看到其中一些圖片附件的縮略圖,需要進一步查看,可以雙擊圖片即可實現預覽效果。
附件管理的上傳界面如下所示,可以從本地選擇多個文件一併上傳,每個文件上傳成功後立即顯示狀態。
以上就是一些附件管理和使用的界面,這些界面有助於我們針對性的對特定的附件進行查看、維護管理。
2、附件的歸檔管理
附件的處理,我們通常是把它上傳到指定的目錄下麵,這個目錄可以是配置好的特定目錄,不過隨著程式的運行,這個目錄的附件會越來越多,更加難以管理,對於一些病歷圖片、視頻信息這些比較重要的資料,我們往往是需要進行歸檔備份起來,以便在某個數據災難後進行恢復,把損失降到最少。
歸檔文件還有一個作用,就是我們可以以資源管理器的方式同一打開一個目錄,然後在裡面尋找或者查看該記錄相關的所有附件信息,這種比在某個界面附件分組中尋找指定的附件,提供更廣範圍的指引。
上圖就是在實際項目中,需要直接打開某個特定目錄的文件,然後查找這個目錄下的文件或者打開查看詳細信息。這裡可能會問,單機版可以直接打開本地目錄,如果是混合框架,數據和文件集中在雲端伺服器的,你如何打開對應的目錄文件呢?
這裡其實我們普通的Winform程式是可以直接打開本地文件,如果是使用Web API或者WCF通訊的混合框架模式,則是通過文件路徑的方式,從伺服器端檢索對應的文件列表信息,然後進行呈現的,因此就需要在附件管理模塊提供對應的介面來獲取文件信息了。
下麵我們來介紹一下,歸檔處理的實現,以及通過文件路徑獲取對應文件列表的處理。
由於病歷附件這裡我做成了一個用戶控制項的方式,方便各個模塊重用的,因此歸檔的方式我做了一個功能按鈕,並通過事件的方式給外部實現邏輯。
我們通過定義事件的方式來定義這個處理,然後外部可以實現這個事件即可。
按鈕的事件處理,就是調用這個我們自定義的事件處理即可。
private void btnArchive_Click(object sender, EventArgs e) { if (OnArchived != null) { string tips = "您確認需要進行圖片歸檔處理嗎?"; if (MessageDxUtil.ShowYesNoAndTips(tips) == DialogResult.Yes) { //執行歸檔處理 OnArchived(this.info); } } }
而編輯的窗體,我們顯示數據的時候,初始化這個事件的處理即可。
/// <summary> /// 數據顯示的函數 /// </summary> public override void DisplayData() { InitDictItem();//數據字典載入(公用) BindPatient();//綁定顯示病人資料 //綁定數據並顯示 attchmentControl.BindData(PatientInfo.ID); attchmentControl.OnArchived += AttchmentControl_OnArchived; attchmentControl.Dock = DockStyle.Fill; this.pageAttachment.Controls.Clear(); this.pageAttachment.Controls.Add(attchmentControl); BindData(); }
而對於處理歸檔的事件,主要就是我們確定好歸檔的目錄(部分信息),然後交給伺服器端處理進行歸檔即可。這裡確定目錄的信息,有患者姓名和診斷部分信息組成。
而服務端的最終處理邏輯,也就是根據對應附件的ID,然後找出對應的文件,移動原來文件到新的目錄裡面,並更新資料庫記錄中的附件路徑信息即可。
....
為了實現對文件路徑的文件檢索和下載指定文件,我們需要擴展一下原來附件管理通過ID獲取和下載文件的方式,原來的是從資料庫獲取文件路徑,並打開下載文件;而擴展後可以通過路徑方式獲取文件信息。