Silverlight 結構分析

作者: 葡萄城控件技術團隊博客  來源: 博客園  發布時間: 2010-11-21 21:53  閱讀: 791 次  推薦: 0   原文鏈接   [收藏]  

  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。

  寫的比較倉促,希望批評指正。

0
0
 
標簽:Silverlight
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()