前言] 寫這篇Post源于我既做過.NET開發(fā)又做過J2EE開發(fā)的經(jīng)歷。在這樣的轉(zhuǎn)變過程中,我對(duì)單一平臺(tái)開發(fā)所帶來的思維局限性有了很多清晰卻零散的想法。在看了振河兄的頁面間傳遞變量的方法及使用范圍的討論之后,我更能體會(huì)到在不同的平臺(tái)進(jìn)行開發(fā),思維方式會(huì)是如此之不同,原來那些零散的想法也隨之不斷在腦海中涌現(xiàn),讓我有了寫下這篇Post的沖動(dòng)。其實(shí)我一直都在宣揚(yáng)一種觀點(diǎn):技術(shù)之間是相通的,精于觸類旁通,善于聯(lián)想是我們程序員應(yīng)有的優(yōu)勢。我們在專注.NET技術(shù)的時(shí)候,不妨在工作間隙休息的時(shí)候看看.NET外面的世界。
提到.NET和J2EE,一般都會(huì)想到它們之間兵戎相見,水火不容的關(guān)系,畢竟兩者都在努力地去虜獲程序員的青睞,占領(lǐng)更多的市場份額。我無意去鼓吹.NET是如何如何之強(qiáng)大,J2EE是如何如何的成熟,也無意去探究NHibernate,Spring.NET等等Project的起源,只想從一個(gè)程序員的角度去看待兩者在互相競爭的過程當(dāng)中到底相互借鑒了什么,同時(shí)探討一下同時(shí)了解兩個(gè)領(lǐng)域知識(shí)的必要性。好,讓我們言歸正傳。
還記得2003年初,我到了DELL公司實(shí)習(xí),所承擔(dān)的工作任務(wù)就是建立一個(gè)Web Application供多個(gè)有密切聯(lián)系的部門使用,以提高部門間的協(xié)作程度。在選擇用什么技術(shù)來做這個(gè)Web Application的時(shí)候,我放棄了比較熟悉的ASP,進(jìn)而選擇了ASP.NET。正是做這個(gè)Project,我跟ASP.NET乃至.NET結(jié)下了不解之緣。當(dāng)時(shí)第一次接觸到ASP.NET,第一個(gè)感覺就是,它比ASP好多了,再也不用像寫ASP那樣在HTML嵌套著一堆堆的Scriptlet,動(dòng)態(tài)內(nèi)容的呈現(xiàn)都包含在一個(gè)個(gè)方法中,如Page.OnInit()和Page.OnLoad()等等,這些方法讓我看到Client端JS方法的影子。在開發(fā)ASP.NET頁面的過程中,我需要做的就是在頁面中引入不同的Web Control或者是HTML Control,這些Controls與HTML標(biāo)簽是何等的類似,除了它有ASP的prefix和那時(shí)看起來如Magic一般的runat="server"。這樣的相似性讓熟悉HTML和JS的我很快掌握了ASP.NET的基本應(yīng)用,而我也以極高的效率完成了公司分配給我的任務(wù),盡管我對(duì)諸如Request、Response、Session和Application這樣的對(duì)象并不是十分了解。ASP.NET所帶來的進(jìn)步是革命性的,難怪有朋友認(rèn)為ASP.NET是.NET家族中最為成功的產(chǎn)品了。我當(dāng)時(shí)只是拿ASP.NET來跟ASP作對(duì)比,其優(yōu)越性自然顯露無遺,尤其是在控件設(shè)計(jì)方面的優(yōu)勢。事實(shí)上直到后來進(jìn)入J2EE的開發(fā)領(lǐng)域,我依然對(duì)ASP.NET的開發(fā)方式贊賞有加。Microsoft在技術(shù)的創(chuàng)新上一直秉持削弱領(lǐng)域開發(fā)特性的原則,讓開發(fā)人員能夠在不同的開發(fā)領(lǐng)域中都可以輕松上手,游刃有余。ASP.NET的出現(xiàn)帶來了WebForm,而在桌面程序開發(fā)中則有WinForm,兩者相通的地方隨處可見,這讓原有的桌面程序開發(fā)人員可以平滑的過渡到Web Application開發(fā)中來; ASP.NET對(duì)于控件在設(shè)計(jì)以及使用上的支持堪稱完美,也為網(wǎng)頁設(shè)計(jì)人員進(jìn)入ASP.NET開發(fā)領(lǐng)域掃除了不少的障礙。反觀J2EE領(lǐng)域,做Swing開發(fā)的人員,如果要學(xué)習(xí)Web的開發(fā),原有的知識(shí)幾乎無用武之地了。在這個(gè)人氣就是財(cái)富的年代,在一定層面上求同存異,讓開發(fā)人員能夠一通百通,無疑是一個(gè)十分明智的做法。J2EE領(lǐng)域也開始意識(shí)到了這一點(diǎn),將Swing概念應(yīng)用到Web開發(fā)的Wicket Framwork的發(fā)布著實(shí)是一個(gè)極大的進(jìn)步啊。J2EE在降低Web開發(fā)的難度,吸引入門級(jí)開發(fā)人員方面需要向.NET好好請(qǐng)教一番了。
好,個(gè)人經(jīng)歷接著說。2003年底,我進(jìn)入了一家軟件公司從事J2EE的開發(fā)工作。當(dāng)時(shí)公司技術(shù)部門負(fù)責(zé)人在面試我的時(shí)候提到了我缺乏J2EE的開發(fā)經(jīng)驗(yàn)的問題,我信心滿滿的告訴他,我做過.NET的項(xiàng)目,而.NET和J2EE都是專注在企業(yè)級(jí)應(yīng)用上的,因此肯定會(huì)很快上手,不會(huì)有什么問題。然而后來的工作證明了平臺(tái)之間的差異性是很大的,從.NET過渡到J2EE并不是一件輕松的事情。沒有了熟悉的Web Control,取而代之的是簡陋的Tag Library; 沒有了簡單易用的Event-Driven的方法,呈現(xiàn)眼前的是doGet、doPost、doHead和service這樣看似丑陋的面孔。蛻變的過程是痛苦的,但是蛻變帶來了進(jìn)化。開發(fā)方式的改變讓我可以從一個(gè)更加深入的層面去看待Web開發(fā),而我開始重新認(rèn)識(shí)Web Application。Web開發(fā)的復(fù)雜性在很大程度上源于Http是一個(gè)無狀態(tài)的連接協(xié)議,Web Server不管你是Michael,還是Jordon,只要你在瀏覽器上使用了相同的URL,就會(huì)得到相同的資源。在這里,你必須清楚URL到底是什么的縮寫。也許你會(huì)站出來反駁我剛才所說的結(jié)論,但是這種情況在只有靜態(tài)HTML網(wǎng)頁的年代是絕對(duì)正確的。隨著時(shí)代的發(fā)展,資源已經(jīng)不再局限于靜態(tài)的HTML網(wǎng)頁,隨之出現(xiàn)了所謂的動(dòng)態(tài)網(wǎng)頁。這里的動(dòng)態(tài)不是指充滿Flash動(dòng)畫的網(wǎng)頁,而是指網(wǎng)頁的內(nèi)容會(huì)根據(jù)不同的Request而發(fā)生變化。雖然Web的內(nèi)容開始個(gè)性化了,但是仍然沒有脫離Client發(fā)送Request,Server返回Response這樣的模式。由于Http是一個(gè)無狀態(tài)的連接協(xié)議,為了能夠識(shí)別用戶訪問同一資源的狀態(tài),在J2EE的世界里,我們就得從Request、Response和Session這樣的對(duì)象入手,控制這些對(duì)象的Life Cycle。因此,我們哪怕要進(jìn)行最為簡單的Web應(yīng)用程序,都必須對(duì)Request、Response和Session這樣的對(duì)象有充分的了解。關(guān)注這些基本的對(duì)象,讓我們對(duì)于應(yīng)用程序的Flow有更為準(zhǔn)確的把握,能夠更好地進(jìn)行模塊地劃分,便于開發(fā)人員進(jìn)行協(xié)作。然而在.NET的世界里,對(duì)Request和Session這樣的對(duì)象關(guān)注遠(yuǎn)不如對(duì)Page的關(guān)注,從振河兄的Post就可見一斑了。ASP.NET開發(fā)降低了開發(fā)難度,卻在一定程度上阻礙了開發(fā)人員對(duì)Web Application的整體把握,正如春魚兄的Feedback中提到的,過分糾纏頁面之間關(guān)系,“不利于系統(tǒng)整體架構(gòu)的良好設(shè)計(jì)”。J2EE的應(yīng)用程序可以讓程序員在Web Application的整體架構(gòu)上有一個(gè)很好的體現(xiàn),.NET還是得好好努力啊!建議.NET的程序員能夠嘗試著利用J2EE的技術(shù)來開發(fā)一個(gè)簡單的Web Application,我相信這樣的一個(gè)過程會(huì)讓你對(duì)Web開發(fā)有進(jìn)一步的認(rèn)識(shí)。
提到.NET和J2EE,一般都會(huì)想到它們之間兵戎相見,水火不容的關(guān)系,畢竟兩者都在努力地去虜獲程序員的青睞,占領(lǐng)更多的市場份額。我無意去鼓吹.NET是如何如何之強(qiáng)大,J2EE是如何如何的成熟,也無意去探究NHibernate,Spring.NET等等Project的起源,只想從一個(gè)程序員的角度去看待兩者在互相競爭的過程當(dāng)中到底相互借鑒了什么,同時(shí)探討一下同時(shí)了解兩個(gè)領(lǐng)域知識(shí)的必要性。好,讓我們言歸正傳。
還記得2003年初,我到了DELL公司實(shí)習(xí),所承擔(dān)的工作任務(wù)就是建立一個(gè)Web Application供多個(gè)有密切聯(lián)系的部門使用,以提高部門間的協(xié)作程度。在選擇用什么技術(shù)來做這個(gè)Web Application的時(shí)候,我放棄了比較熟悉的ASP,進(jìn)而選擇了ASP.NET。正是做這個(gè)Project,我跟ASP.NET乃至.NET結(jié)下了不解之緣。當(dāng)時(shí)第一次接觸到ASP.NET,第一個(gè)感覺就是,它比ASP好多了,再也不用像寫ASP那樣在HTML嵌套著一堆堆的Scriptlet,動(dòng)態(tài)內(nèi)容的呈現(xiàn)都包含在一個(gè)個(gè)方法中,如Page.OnInit()和Page.OnLoad()等等,這些方法讓我看到Client端JS方法的影子。在開發(fā)ASP.NET頁面的過程中,我需要做的就是在頁面中引入不同的Web Control或者是HTML Control,這些Controls與HTML標(biāo)簽是何等的類似,除了它有ASP的prefix和那時(shí)看起來如Magic一般的runat="server"。這樣的相似性讓熟悉HTML和JS的我很快掌握了ASP.NET的基本應(yīng)用,而我也以極高的效率完成了公司分配給我的任務(wù),盡管我對(duì)諸如Request、Response、Session和Application這樣的對(duì)象并不是十分了解。ASP.NET所帶來的進(jìn)步是革命性的,難怪有朋友認(rèn)為ASP.NET是.NET家族中最為成功的產(chǎn)品了。我當(dāng)時(shí)只是拿ASP.NET來跟ASP作對(duì)比,其優(yōu)越性自然顯露無遺,尤其是在控件設(shè)計(jì)方面的優(yōu)勢。事實(shí)上直到后來進(jìn)入J2EE的開發(fā)領(lǐng)域,我依然對(duì)ASP.NET的開發(fā)方式贊賞有加。Microsoft在技術(shù)的創(chuàng)新上一直秉持削弱領(lǐng)域開發(fā)特性的原則,讓開發(fā)人員能夠在不同的開發(fā)領(lǐng)域中都可以輕松上手,游刃有余。ASP.NET的出現(xiàn)帶來了WebForm,而在桌面程序開發(fā)中則有WinForm,兩者相通的地方隨處可見,這讓原有的桌面程序開發(fā)人員可以平滑的過渡到Web Application開發(fā)中來; ASP.NET對(duì)于控件在設(shè)計(jì)以及使用上的支持堪稱完美,也為網(wǎng)頁設(shè)計(jì)人員進(jìn)入ASP.NET開發(fā)領(lǐng)域掃除了不少的障礙。反觀J2EE領(lǐng)域,做Swing開發(fā)的人員,如果要學(xué)習(xí)Web的開發(fā),原有的知識(shí)幾乎無用武之地了。在這個(gè)人氣就是財(cái)富的年代,在一定層面上求同存異,讓開發(fā)人員能夠一通百通,無疑是一個(gè)十分明智的做法。J2EE領(lǐng)域也開始意識(shí)到了這一點(diǎn),將Swing概念應(yīng)用到Web開發(fā)的Wicket Framwork的發(fā)布著實(shí)是一個(gè)極大的進(jìn)步啊。J2EE在降低Web開發(fā)的難度,吸引入門級(jí)開發(fā)人員方面需要向.NET好好請(qǐng)教一番了。
好,個(gè)人經(jīng)歷接著說。2003年底,我進(jìn)入了一家軟件公司從事J2EE的開發(fā)工作。當(dāng)時(shí)公司技術(shù)部門負(fù)責(zé)人在面試我的時(shí)候提到了我缺乏J2EE的開發(fā)經(jīng)驗(yàn)的問題,我信心滿滿的告訴他,我做過.NET的項(xiàng)目,而.NET和J2EE都是專注在企業(yè)級(jí)應(yīng)用上的,因此肯定會(huì)很快上手,不會(huì)有什么問題。然而后來的工作證明了平臺(tái)之間的差異性是很大的,從.NET過渡到J2EE并不是一件輕松的事情。沒有了熟悉的Web Control,取而代之的是簡陋的Tag Library; 沒有了簡單易用的Event-Driven的方法,呈現(xiàn)眼前的是doGet、doPost、doHead和service這樣看似丑陋的面孔。蛻變的過程是痛苦的,但是蛻變帶來了進(jìn)化。開發(fā)方式的改變讓我可以從一個(gè)更加深入的層面去看待Web開發(fā),而我開始重新認(rèn)識(shí)Web Application。Web開發(fā)的復(fù)雜性在很大程度上源于Http是一個(gè)無狀態(tài)的連接協(xié)議,Web Server不管你是Michael,還是Jordon,只要你在瀏覽器上使用了相同的URL,就會(huì)得到相同的資源。在這里,你必須清楚URL到底是什么的縮寫。也許你會(huì)站出來反駁我剛才所說的結(jié)論,但是這種情況在只有靜態(tài)HTML網(wǎng)頁的年代是絕對(duì)正確的。隨著時(shí)代的發(fā)展,資源已經(jīng)不再局限于靜態(tài)的HTML網(wǎng)頁,隨之出現(xiàn)了所謂的動(dòng)態(tài)網(wǎng)頁。這里的動(dòng)態(tài)不是指充滿Flash動(dòng)畫的網(wǎng)頁,而是指網(wǎng)頁的內(nèi)容會(huì)根據(jù)不同的Request而發(fā)生變化。雖然Web的內(nèi)容開始個(gè)性化了,但是仍然沒有脫離Client發(fā)送Request,Server返回Response這樣的模式。由于Http是一個(gè)無狀態(tài)的連接協(xié)議,為了能夠識(shí)別用戶訪問同一資源的狀態(tài),在J2EE的世界里,我們就得從Request、Response和Session這樣的對(duì)象入手,控制這些對(duì)象的Life Cycle。因此,我們哪怕要進(jìn)行最為簡單的Web應(yīng)用程序,都必須對(duì)Request、Response和Session這樣的對(duì)象有充分的了解。關(guān)注這些基本的對(duì)象,讓我們對(duì)于應(yīng)用程序的Flow有更為準(zhǔn)確的把握,能夠更好地進(jìn)行模塊地劃分,便于開發(fā)人員進(jìn)行協(xié)作。然而在.NET的世界里,對(duì)Request和Session這樣的對(duì)象關(guān)注遠(yuǎn)不如對(duì)Page的關(guān)注,從振河兄的Post就可見一斑了。ASP.NET開發(fā)降低了開發(fā)難度,卻在一定程度上阻礙了開發(fā)人員對(duì)Web Application的整體把握,正如春魚兄的Feedback中提到的,過分糾纏頁面之間關(guān)系,“不利于系統(tǒng)整體架構(gòu)的良好設(shè)計(jì)”。J2EE的應(yīng)用程序可以讓程序員在Web Application的整體架構(gòu)上有一個(gè)很好的體現(xiàn),.NET還是得好好努力啊!建議.NET的程序員能夠嘗試著利用J2EE的技術(shù)來開發(fā)一個(gè)簡單的Web Application,我相信這樣的一個(gè)過程會(huì)讓你對(duì)Web開發(fā)有進(jìn)一步的認(rèn)識(shí)。
jwebee
我的個(gè)人網(wǎng)站