標籤:使用 檔案 問題 io 代碼 管理
從silverlight5開始,可以在項目設定中勾選“在瀏覽器內運行時需要更高的信任”來達到在瀏覽器內運行提權silverlight用戶端的目的,在個特性很有用處。
可我使用這個功能時遇到了一個奇怪的故障:我使用visual studio 2010開發一個silverlight5項目,發現上面那個設定項不起作用,無論是否勾選它,代碼中的 App.Current.HasElevatedPermissions總會返回false,那些需要提權啟動並執行操作自然也都會失敗。累死好幾千腦細胞後 才發現故障原因。
當你勾選“在瀏覽器內運行時需要更高的信任”時,visual studio會做下面幾件事情:
1、在silverlight的專案檔(.csproj)中增加內容:<RequireInBrowserElevation>true</RequireInBrowserElevation>
2、在項目的Properties檔案夾中增加一個檔案:InBrowserSettings.xml。
3、在silverlight的專案檔(.csproj)中增加內容:<InBrowserSettingsFile>Properties\InBrowserSettings.xml</InBrowserSettingsFile>
如果上面步驟都順利完成就沒什麼問題。但如果項目的Properties檔案夾正好有一個名為InBrowserSettings.xml的檔案,就可能會有下面種故障發生:
1、這個檔案只是在檔案夾裡,沒包含在項目中,那麼visual studio增加InBrowserSettings.xml會失敗,但不會給你任何提示。結果是看似“在瀏覽器內運行時需要更高的信任”這一項已經被勾 選,但實際上並沒有成功的提升silverlight運行許可權,需要提權啟動並執行代碼都會失敗,這個莫名其妙的故障搞的我焦頭爛額。要解決這個故障,可以在 方案總管中查看所有檔案,把InBrowserSettings.xml手動包含在項目中,並使用記事本開啟專案檔手動添加 上<InBrowserSettingsFile>Properties\InBrowserSettings.xml</InBrowserSettingsFile>。 如果勾選“在瀏覽器內運行時需要更高的信任”後發現visual studio並沒在Properties檔案夾中增加InBrowserSettings.xml檔案,可以判斷這個故障已被觸發。
2、這個檔案已經在這個檔案夾裡,而且已包含在項目中。visual studio會試圖根據你的勾選來改變InBrowserSettings.xml中的內容,如果InBrowserSettings.xml檔案正好處 於唯讀狀態(比如它被簽入了),那麼visual studio改變檔案內容時會出錯,結果是visual studio乾脆的崩潰退出,退出前也不會給你任何提示。所以改變“在瀏覽器內運行時需要更高的信任”的勾選前,如果 InBrowserSettings.xml檔案已被簽入或由於其它原因設了唯讀,請提前把它簽出或去掉唯讀屬性。
上述兩個故障中,第1個故障原因非常隱蔽。我曾經奇怪,為什麼這麼巧,偏偏在Properties檔案夾偏偏有一個名為 InBrowserSettings.xml的檔案。後來經過詢問同事才知道了原因,這不是一個巧合。我的同事曾經實驗性的勾選“在瀏覽器內運行時需要提 升的信任”,visual studio在他的項目中增加了InBrowserSettings.xml,他實驗完後通過撤銷簽出項目取消了自己的操作。他認為這樣就徹底復原了自己 的動作,但實際上不是,撤銷簽出只是撤銷在項目中包含InBrowserSettings.xml檔案,並不在專案檔夾中刪除這個檔案,所以他再次簽入 項目時,InBrowserSettings.xml就會被簽入到TFS裡,另外的同事擷取新版本時會就會把這個未包括在項目中的 InBrowserSettings.xml檔案隱形擷取到Properties檔案夾中,從面引發這個故障。
希望能幫到大家,別再有人踩到這個地雷。