本節介紹asp.net對視圖信息的加密功能。Page.RegisterRequiresViewStateEncryption方法就是將控件注冊為需要視圖狀態加密的控件。如果您要開發用于處理潛在的敏感信息的自定義控件,請調用RegisterRequiresViewStateEncryption方法向頁注冊控件,并確保該控件的視圖狀態信息已加密。
RegisterRequiresViewStateEncryption方法必須在頁生命周期的PReRender階段中或該階段之前調用,下面在前面ViewStateControl控件中重寫OnPreRender方法并加入視圖加密功能,增加后的代碼段如下:
protected override void OnPreRender(EventArgs e)
{
this.Page.RegisterRequiresViewStateEncryption();
base.OnPreRender(e);
}
編譯控件并在瀏覽器中重新運行,可以看到發送到客戶端的隱藏域視圖控件中的值由:
<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value= "/wEPDwULLTE3NjU0NjM4OTEPZBYCAgMPZBYEAgEPDw8WAh4OVGV4dF9WaWV3U3RhdGUFIuaIkeaYr+eUqFZpZXdTdGF0ZeWuueWZqOWtmOWCqOeahCFkFCsAAhYEHglCYWNrQ29sb3IKAB4EXyFTQgIIZ2QCBw8PFgIeBFRleHQF9QN0aGlzLlZpZXdTdGF0ZUNvbnRyb2wxLlRleHRfTm9WaWV3U3RhdGXlsZ7mgKcg5rKh5pyJ5L+d5a2Y6KeG5Zu+54q25oCBIDxJbWcgc3Jj變成了已經加密的散列碼:
<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value= "J62G77yDi1rdf8+ZXszW1d3eAPnuzO8h2MCNPEN2HR6daQNjLLamfq4EHwWRRJ16S6kHFp43gwVPkMB9RPQtMaI5Gc+lZ9orQjsZWpvaVDTBI4fF6wFRj7qY1r2hREghEQYM/e1a+JX9oiWk1kUs8vFJ3SNeXCkCdDb7fQtr6DlCKsbCGGWDrawgiIsI0O5pnYMPloa+z74clY6/DYZ23BIAZNNYDLML/e7mVIzSS+V4FBZsXxBBdRx1oWJ60wjrfkScl1g0Dpbn+LZ2NIu7nh2t5Xu8iTW1NmjSfUoH9ymBmQkCNek3jaex18n9wBOdLGsQ8ZxO/hAGVqbcqTQStiuRYezjvm8T9Q0U9cj9SI+FnS2PktVHXqh6qLsjH1Dlwm+qFyjHK2fvbH+WA2NZUq3HzObR4GzNFRlZn8ZliO/FDJEKyH+x9X7qneaJs9dTg6mo/qbvI+S0W1viQ/nj/OrC3PoiLwvwyd1WjBlND4B21rVjnoq/J+jPNQGE+AdQR2fW3kYAtGhKf6PSVmUm9fZ26JY2rkYw2vBahPWmxHqnf9V5yt/0D3LP9Mx7KYay4PAItTeEzIT4G5I0Hp65a8d/QQJbQTCs1Qz798Mei66mqF8QrOBxR2EUsS+uCekxQe+2xDhX2kkxntoqxgRJ4/n8cdKr2Z+K3F3IEmxObo+QvQ5wUtMWrsKIY8Jad562zCNBGjlyU72i+KuORHQCBoXRgt5vPeIBpdjb0Vk3tb6t7g2T5yFyB7PBTqEwV43Ws4/BPxYsdr9YCNOJd/TB6cDI5FUS/dGYTej2EZt2HOPCM758WeEwBQZuG+t1dFEZU6+vicImHDV8ifCwNv+Yhw==" />
</div>
還可以指定視圖狀態信息的加密模式,通過系統枚舉ViewStateEncryptionMode來設置,該枚舉可以控制是否加密視圖狀態信息,它有三個枚舉項。
枚舉成員 說 明
Auto 如果控件通過調用RegisterRequiresViewStateEncryption方法請求加密,則加密視圖狀態信息;否則不加密。此值是Page.ViewStateEncryptionMode屬性的默認值
Always 強制加密視圖狀態信息,而不管有沒有調用
Never 即使控件請求加密,也不加密視圖狀態信息
以上枚舉項除了在控件中設置外,還可以在配置文件配置應用程序級別,或者在Page頁面中配置成頁面級別。在控件或頁面中應用時僅作如下設置:
this.Page.ViewStateEncryptionMode = ViewStateEncryptionMode.Auto;
this.Page.RegisterRequiresViewStateEncryption();
經過如上設置后,頁框架會自動完成加密與解密功能。對該功能再補充兩點:
(1)加密視圖狀態肯定會影響到應用程序的性能,所以使用時要謹慎。
(2)只要頁面中有任何一個控件要求對視圖狀態進行加密,那么頁面中所有的視圖狀態也都將被加密。目前ASP.NET還沒有實現針頁面中某個控件視圖加密功能(在調用時不管是在控件中還是在頁面中都是調用頁面控件Page的方法RegisterRequiresViewStateEncryption,且該方法沒有任何可重載方法)。
新聞熱點
疑難解答