構(gòu)建ASP.NET網(wǎng)站十大必備工具
原創(chuàng)【51CTO 11月30日外電頭條】最近使用ASP.NET為公司構(gòu)建了一個簡單的公共網(wǎng)站(該網(wǎng)站的地址:http://superexpert.com/)。在這個過程中,我們使用了數(shù)量很多的免費工具,如果把構(gòu)建ASP.NET網(wǎng)站的必備工具總結(jié)一下,將會是一件十分有趣的事情。這些工具既支持ASP.NET Web Forms又支持ASP.NET MVC。
性能工具
讀了兩本關(guān)于網(wǎng)站的前端性能的書(這兩本優(yōu)秀的圖書分別是:《High Performance Web Sites》 和 《Even Faster Web Sites》,作者是Steve Souders)以后,我對網(wǎng)站的前端性能十分敏感。根據(jù)Steve Souders的性能黃金法則:
“首先應(yīng)該對前端性能進行優(yōu)化,終端用戶的響應(yīng)時間有80%或更多花費在這方面了。”你可以使用下面這些工具來減少ASP.NET應(yīng)用程序使用的圖像的尺寸,以及JavaScript文件,CSS文件的體積。
1,Sprite and Image Optimization Framework
在A List Apart的一篇文章中(這篇文章的題目是:CSS sprites: Image Slicing’s Kiss of Death,具體可以參考:http://www.alistapart.com/articles/sprites),首次提到了CSS sprites。當你使用sprites的時候,你需要把一個網(wǎng)站使用的多個圖像合并成為一個單一的圖像。然后,在一個Web頁面中,使用CSS trickery來顯示特定的“子圖像”。
sprites的主要優(yōu)勢是,顯示一個Web頁面的時候,它可以有效地減少請求的次數(shù)。請求一個大圖像比請求多個小圖像快得多。一般來說,通過網(wǎng)線傳輸?shù)馁Y源(圖像,JavaScript文件,CSS文件)越多,你的網(wǎng)站就越慢。
但是,大多數(shù)人都不愿意使用sprites,因為使用sprites需要做很多的工作。你必須要合并所有的圖像,然后編寫合適的CSS規(guī)則來顯示子圖像。微軟的 Sprite and Image Optimization Framework 可以讓我們省去這些繁瑣的工作。這個框架可以自動地為你合并圖像。此外,這個框架還包含一個ASP.NET Web Forms control 和一個ASP.NET MVC helper,它們可以讓顯示子圖像變得更加容易。你可以從CodePlex下載 Sprite and Image Optimization Framework。
下載地址:http://aspnet.codeplex.com/releases/view/50869
Sprite and Image Optimization Framework是 Morgan McClean 編寫的。在微軟,他的辦公室和我的辦公室緊挨著。Morgan是一個十分聰明的人,他是加拿大的實習(xí)生。當他構(gòu)建這個框架的時候,我們一起討論了那個框架。(據(jù)我所知,他還在繼續(xù)開發(fā)這個框架。)
Morgan給這個框架添加了一些高級的功能。例如,Sprite and Image Optimization Framework支持“image inlining”。當你使用“image inlining”的時候,真正的圖像被存儲在CSS文件中。這是一個“image inlining”的例子:
- .Home_StephenWalther_small-jpg
- {
- width:75px;
- height:100px;
- background: url(
- GdBTUEAALGOfPtRkwAAACBjSFJNAACHDwAAjA8AAP1SAACBQAAAfXkAAOmLAAA85QAAGcxzPIV3AAAKL
- s+zNfREAAAAASUVORK5CYII=) no-repeat 0% 0%;
- }
真正的圖像(在這個例子中,是一個顯示在Superexpert.com網(wǎng)站主頁上的圖片)被存儲在這個CSS文件中。如果你瀏覽一下Superexpert.com網(wǎng)站,你會發(fā)現(xiàn)幾乎沒有幾個獨立的圖像可以被下載。在下面這張截圖中,所有帶紅框的圖像都是使用CSS sprites的:
不幸的是,使用 Sprite and Image Optimization Framework 的時候,有一些“陷阱”需要注意一下。為了繞開這些“陷阱”,還有一些周邊的工作需要做。在我以后的文章中,我會詳細講述這些“陷阱”都是什么,以及如何繞開這些“陷阱”。
2,Microsoft Ajax Minifier
無論何時,你都應(yīng)該通過“far future header”來合并,最小化(minify),壓縮和緩存所有的JavaScript文件和CSS文件。Microsoft Ajax Minifier可以讓最小化JavaScript文件和CSS文件變得更加容易。
請不要把最小化和壓縮搞混了。這兩個工作你都需要做。根據(jù)Souders的觀點,在你壓縮了一個JavaScript文件以后,你還可以通過最小化來減少20%(平均)的體積。
當你最小化一個JavaScript文件,或者一個CSS文件的時候,你可以使用各種技巧在壓縮那個文件以前盡可能地減少那個文件的尺寸。例如,你可以通過用短的JavaScript變量名替換長的JavaScript變量名的方式,和移除非必需的空白和注釋的方式來最小化一個JavaScript。你可以通過同樣的方式來最小化CSS文件,例如,用短的color名(#fff)替換長的color名(#fffff)。
Microsoft Ajax Minifier是微軟的員工 Ron Logan 開發(fā)的。在內(nèi)部,幾個大型的微軟網(wǎng)站都使用了這個工具。在ASP.NET團隊中,我們也使用這個工具。我認為Ron可以把這個工具發(fā)布到CodePlex上,讓世界上的所有人都可以使用這個優(yōu)秀的工具。你可以從ASP.NET Ajax站點下載這個工具:
下載地址:http://www.asp.net/ajaxlibrary/Download.ashx
這個工具的文檔可以參考:http://www.asp.net/ajaxlibrary/AjaxMinDocumentation.ashx
我為Microsoft Ajax Minifier創(chuàng)建了一個安裝程序。當創(chuàng)建那個安裝程序的時候,我還創(chuàng)建了一個Visual Studio生成任務(wù),當你在Visual Studio中自動地進行生成的時候,它可以讓最小化JavaScript文件和CSS文件變得更加容易。你可以通過《Ajax Minifier Quick Start》來學(xué)習(xí)如何配制這個生成任務(wù)。 (關(guān)于《Ajax Minifier Quick Start》,具體可以參考:http://www.asp.net/ajaxlibrary/AjaxMinQuickStart.ashx)
3,ySlow
ySlow這個工具是Yahoo提供的,它是一個免費的Firefox擴展。它可以讓你測試你的網(wǎng)站的前端。
ySlow的下載地址:http://developer.yahoo.com/yslow/
這是“Superexpert.com”網(wǎng)站當前的測試結(jié)果:
“Superexpert.com”網(wǎng)站的總體得分是“B”(不是很完美,但是也不錯了)。ySlow這個工具并不是盡善盡美的。例如,雖然Superexpert.com網(wǎng)站使用了支JavaScript庫(例如:jQuery)的Microsoft Ajax Content Delivery Network(關(guān)于Microsoft Ajax Content Delivery Network,具體可以參考:http://www.asp.net/ajaxlibrary/cdn.ashx),但是還是因為沒有使用Content Delivery Network而得到了“F”。
正常運行時間
當一個網(wǎng)站發(fā)布以后,你肯定希望你的網(wǎng)站不會遇到任何問題,一直處在正常運行狀態(tài)之中?,F(xiàn)在,我使用下面這些工具來監(jiān)控“Superexpert.com”網(wǎng)站,確保它一直處在正常運行狀態(tài)之中。
#p#
4,ELMAH
ELMAH 是 Error Logging Modules and Handlers for ASP.NET 的縮寫。ELMAH可以讓你記錄下你的網(wǎng)站發(fā)生的任何一個錯誤,在將來,你可以重新檢查這些錯誤。你可以從ELMAH項目的官方網(wǎng)站免費下載ELMAH:http://code.google.com/p/elmah/。
ELMAH既支持ASP.NET Web Forms 又支持 ASP.NET MVC。你可以對ELMAH進行配置來存儲各種不同的錯誤(XML文件,事件日志,Access數(shù)據(jù)庫,SQL數(shù)據(jù)庫,Oracle數(shù)據(jù)庫,或者計算機RAM。)你還可以讓ELMAH在錯誤發(fā)生的時候,把錯誤信息email給你。
在默認情況下,在一個已經(jīng)安裝ELMAH的網(wǎng)站中,你可以通過請求的elmah.axd頁面的方式來訪問ELMAH。這是“Superexpert.com”網(wǎng)站的elmah頁面的外觀(這個頁面是密碼保護的,因為在一個錯誤信息中,可能會泄露出一些應(yīng)該保密的信息。)
如果你點擊某個錯誤信息,你可以看到原始的ASP.NET的黃屏錯誤信息(雖然這個錯誤信息永遠不會顯示給真正的用戶)。
我使用全新的ASP.NET軟件包管理器 NuGet(過去叫做NuPack)來安裝ELMAH。關(guān)于NuGet,你可以參考Scott Guthrie的博客:http://weblogs.asp.net/scottgu/archive/2010/10/06/announcing-nupack-asp-net-mvc-3-beta-and-webmatrix-beta-2.aspx。你可以從CodePlex下載 NuGet:http://nuget.codeplex.com/。
5,Pingdom
我使用Pingdom來驗證Superexpert.com網(wǎng)站是否總是處在正常運行狀態(tài)之中。你可以通過瀏覽“Pingdom.com”的方式來注冊Pingdom。你可以使用Pingdom來免費監(jiān)控一個網(wǎng)站。
在Pingdom網(wǎng)站上,你可以配置ping你的網(wǎng)站的頻率。我每5分鐘驗證一次Superexpert.com 網(wǎng)站是否總是處在正常運行狀態(tài)之中。我使用Pingdom服務(wù)來驗證它是否可以從那個網(wǎng)站的主頁上檢索到字符串“Contact Us”。
如果你的網(wǎng)站宕機了,你可以對Pingdom進行配置,讓它通過email, Twitter, SMS, 或 iPhone來發(fā)送一個警報。我使用這個Pingdom的iPhone應(yīng)用程序:
6,Host Tracker
如果你的網(wǎng)站宕機了,你需要一些方式來判斷這是本地網(wǎng)絡(luò)的問題,還是對每個人來說,你的網(wǎng)站都宕機了。我使用一個叫做“Host-Tracker.com”的網(wǎng)站來檢查一個網(wǎng)站宕機的程度。
這是“Superexpert.com”網(wǎng)站從世界各地都可以ping通的時候,Host-Tracker顯示的結(jié)果:
注意:Host-Tracker從68個地點(其中包括:Roubaix, France and Scranton, PA等)來ping “Superexpert.com”網(wǎng)站。
調(diào)試
我這里提到的“調(diào)試”的意義十分廣泛。當構(gòu)建一個網(wǎng)站的時候,我使用下面這些工具來驗證我并沒有犯錯誤。
7,HTML Spell Checker
為什么Visual Studio沒有內(nèi)置一個拼寫檢查器?不知道——我覺得這有點不可思議。但是,幸運的是,ASP.NET團隊的前成員編寫了一個免費的拼寫檢查器,你可以在ASP.NET頁面上使用這個拼寫檢查器。
我發(fā)現(xiàn)一個拼寫檢查器是必不可少的。認為你自己的拼寫能力絕對是完美的,只是自欺欺人而已。當我真正地運行拼寫檢查工具,發(fā)現(xiàn)我的所有拼寫錯誤的時候,我恨不得找個地縫鉆進去。
把HTML Spell Checker擴展添加到Visual Studio中的最快方法是在Visual Studio中選擇“Tools”菜單項,然后點擊“Extension Manager”。點擊“Online Gallery”,然后索搜“HTML Spell Checker”:
#p#
8,IIS SEO Toolkit
如果人們無法通過Google找到你的網(wǎng)站,那么還不如不構(gòu)建這個網(wǎng)站。微軟提供了一個優(yōu)秀的IIS擴展,叫做“IIS Search Engine Optimization Toolkit ”(關(guān)于IIS Search Engine Optimization Toolkit 具體可以參考:http://www.iis.net/download/seotoolkit),你可以使用它來檢測出可能會影響頁面排名的問題。你也可以使用它快速地為你的網(wǎng)站創(chuàng)建一個sitemap,你可以把這個sitemap提交給Google或Bing。你甚至可以為一個ASP.NET MVC網(wǎng)站生成一個sitemap。
這是“Superexpert.com”網(wǎng)站的分析報告的概述:
注意:“Sueprexpert.com”網(wǎng)站存在很多的問題。例如,有65個頁面的超鏈接已經(jīng)失效了。你可以進一步查看這些問題的詳細信息,找出這些問題發(fā)生的地點和具體的頁面。
9,LinqPad
如果你的ASP.NET網(wǎng)站需要訪問一個數(shù)據(jù)庫,那么你應(yīng)該使用LINQ to Entities這個實體框架。使用LINQ,會把一些用C#編寫的神奇的查詢轉(zhuǎn)換成SQL查詢。如果你在編寫LINQ查詢的時候不小心謹慎一些的話,你很可能會在無意之間構(gòu)建出一個性能十分糟糕的網(wǎng)站。
LinqPad(LinqPad的官方站點:http://www.linqpad.net/)是一個免費的工具,它可以讓你實驗?zāi)愕腖INQ查詢。它甚至支持Microsoft SQL CE 4 和 Azure。
你可以使用LinqPad來執(zhí)行一個LINQ to Entities查詢,然后看看結(jié)果。你也可以使用它來查看對那個數(shù)據(jù)庫執(zhí)行的SQL語句:
10,.NET Reflector
我每天都使用.NET Reflector。.NET Reflector這個工具可以讓你把一個程序集反匯編成C#或VB.NET代碼。當你沒有真正的源代碼的時候,你可以使用.NET Reflector來查看一個程序集的“源代碼”。你可以從Redgate的網(wǎng)站下載.NET Reflector的免費版本:http://www.red-gate.com/products/reflector/。
我主要使用.NET Reflector來幫助我搞清楚代碼在內(nèi)部是如何工作的。例如,為了更好的理解MVC Image helper是如何工作的,我使用.NET Reflector對the Sprite and Image Optimization Framework進行了反匯編。這是Image helper類的一部分反匯編代碼:
總結(jié)
在這篇博客中,我們討論了我構(gòu)建“Superexpert.com”網(wǎng)站的時候使用的幾個工具。我使用這些工具來提高“Superexpert.com”網(wǎng)站的性能,改善“Superexpert.com”網(wǎng)站的SEO(Search Engine Optimization),確保“Superexpert.com”網(wǎng)站的正常運行時間,或者對“Superexpert.com”網(wǎng)站進行調(diào)試。在這篇博客中討論的所有工具都是免費的。此外,所有這些工具都是既支持 ASP.NET Web Forms 又支持 ASP.NET MVC的。
原文名:10 Essential Tools for building ASP.NET Websites
原文鏈接:http://stephenwalther.com/blog/archive/2010/11/22/10-essential-tools-for-building-asp-net-websites.aspx
【51CTO獨家特稿,轉(zhuǎn)載請表明出處及作者!】
【編輯推薦】