Silverlight 結構分析
Silverlight是微軟提供的一種Web前端應用程序開發框架,是微軟RIA的主要應用程序開發平臺。Silverlight以瀏覽器的插件方式,提供豐富的多媒體展示功能以及更多交互性的Web前端解決方案。
本文的重點在于探討Silverlight的整體架構,以及Silverlight應用程序是如何在瀏覽器中運行的,各個子部分的作用是什么。
1、整體結構
Silverlight是以瀏覽器插件方式運行的,在安裝完Silverlight后,我們來看一下安裝目錄:C:\ProgramFiles\Microsoft Silverlight\4.0.50917.0,主要文件如下:
npctrl.dll
實現了瀏覽器plug-in接口,Silverlight通過這個ActiveX控件與宿主瀏覽器進行交互。該Assembly會調用agcore來進行繪制,以及coreclr來創建CLR,Silverlight應用程序就是依賴于這個CLR中而被運行的。
agcore.dll
Silverlight Presentation Foundation,包括多媒體展示、基于向量的繪制引擎等等。這個DLL為什么會以“ag”打頭哪?在元素周期表中銀(Silver)是47號元素,被稱為AG(拉丁語),所以微軟就把Silverlight的展現層Assembly稱為“agcore”了-:)
coreclr.dll
mscorlib.dll
system.*.dll
Coreclr簡單來說就是CLR for Silverlight,就是專門為Silverlight而定制的CLR,用來執行Silverlight代碼。其他的DLL文件在WPF的類庫中都有,只不過現在尺寸小了很多,這是作為瀏覽器應用所必須的。
下圖是Silverlight architecture的圖例,你可以把上面的DLL對號入座:
2、CoreCLR
如何才能使.Net代碼在Web前端執行,如何才能使我們熟悉的.Net技術繼續適用于Web前端,于是微軟推出了CoreCLR。簡單來說就是CoreCLRbring .NET to Web.
如同CLR可以使得.Net代碼在桌面應用程序中執行一樣,有了CoreCLR,.Net Framework的代碼以及應用程序的代碼就可以在瀏覽器中執行了。
2.1、CoreCLR與CLR
CoreCLR與CLR有什么差別哪?首先兩者是基于同一份代碼庫,其執行引擎完全相同。只是為了使的CLR更適合Web,做了一些事情:
基于Web應用場景,對JIT進行優化,加快程序啟動時間;
只需要提供Workstation GC.
2.2、CoreCLR安全模型
Web應用程序都是不被信任的,你不能容忍一個Web應用程序來操縱用戶本地的數據,或者在瀏覽器中的其他應用程序。
一貫以來,.NET開發人員使用CAS來阻止不受信任的代碼執行特權操作。考慮到Silverlight只需一個沙箱,而該沙箱又等同于 Web頁面中用來運行腳本的沙箱。CoreCLR簡化了安全模型,去掉了CAS模型,定義所有的應用程序代碼都是透明代碼,信任級別最低,它無法提升權限或訪問計算機上的敏感資源或信息。
對于SilverlightOOB的應用來說,可以通過一些配置來使其在受信環境中運行。
2.3、Silverlight BCL
Silverlight base class library是.Net base class library的子集,完全基于原來的代碼基構建。為了適應Web應用的需求,做了一些改變:
減少尺寸
作為瀏覽器插件,用戶需要快速的下載安裝,運行,Silverlight提供的類庫必需具有很小的尺寸。所以基于瀏覽器應用的特點移除一些不必要的特性,例如Console,COM操作,還有CodeAccess Security等等。
添加特性
同時也為Silverlight添加了必要的特性功能,例如IsolatedStorage等等。
2.4、跨平臺支持
Silverlight提供了一個平臺抽象層來支持更多的操作系統例如MacOS X,如下圖:
在PAL層上定義了跟Win32相同的API接口,在Mac操作系統上會被重新定向。
3、運行
3.1、Silverlight運行環境
Silverlight應用程序被托管在瀏覽器中,通過Silverlight插件加載CoreCLR,然后CoreCLR為應用程序創建AppDomian,最后初始化SilverlightApplication類。
下圖是MSDN關于Silverlight運行環境的圖例:
3.2、Silverlight運行順序
最后我們看一下Silverlight應用在瀏覽器中是如何被執行的:
- 瀏覽某個帶有Silverlight的網頁
- 瀏覽器加載Plug-in
- Plug-in創建CoreCLR以及其他的服務
- 同時瀏覽器下載xap文件
- CoreCLR創建AppDomain,最后實例化Application類。
最近再做一些基于Silverlight的控件開發,感覺需要從結構上來梳理一下Silverlight。
寫的比較倉促,希望批評指正。