摘要:面向對象編程做爲主流編程範型,在Web系統設計實現中獲得了很好的應用,但同時也早已暴露出不足,針對面向對象編程思想的不足人們提出了面向方
面編程。面向方面編程很好地解決了橫切關注點的問題,從一個更高的角度對系統進行了分解。本博客較深刻地分析研究了面向方面編程與面向對象編程之間的關係,探討了面向方面編程的技術實現原理,對基於面向方面需求分析、設計、開發相關理論作了進一步的探討和研究,着重研究了面向方面編程在Web系統中的應用。java
針對Web應用系統特色,本文分析設計了一種基於MVC的多層系統架構,並着重分析了系統中具備共性的一些系統級橫切關注點,對象持久化、數據庫鏈接維護、緩存和權限認證,及它們與Web系統各層之間的關係。YJ智能框架針對這些橫切關注點設計出了具體的解決方案。本文最後對比分析了面向方面編程與面向對象編程,總結了面向方面編程的優缺點結合實踐應用提出了一些基於面向方面編程的最佳實踐程序員
基於B/S多層架構的Web系統,因爲更高的安全性、可維護性等特色已經取代C/S架構成爲企業應用的主流,隨着社會的發展,各行各業信息化程度愈來愈高,企業應用需求不斷髮展變化,軟件應用系統須要實現的業務操做愈來愈複雜龐大,同時也對軟件各方面性能,可擴展性、可維護性、安全、穩定等提出了愈來愈高的要求。應用需求的發展不停地挑戰着計算機軟件技術的發展,軟件編程方式經歷了從最初的面向機器、到面向過程、再到面向對象,每一種新的編程方法學的發展,都爲人們提供了一種更爲自然的方式,能夠將系統需求映射爲計算機語言的編程結構。這些編程方法學的不斷髮展可讓人們建立更加複雜的軟件系統。面向對象編程(Object-Oriented Programming簡稱OOP)相比傳統編程模式在構建Web系統時顯出了它的強大功能,成爲了當前主流的編程範型。OOP經過分析、抽象出一系列具備必定屬性與行爲的實例,並經過這些實例之間的協做完成系統的功能,按照功能或行爲對軟件系統進行分割,架構整個系統,很好地解決了數據與操做模塊化編程,相比之前面向過程編程大大解耦了軟件系統。OOP發展到如今出現了不少優秀的面嚮對象語言,如java它是一種純面嚮對象語言,並且java在針對企業應用web系統中提供了一整套基於面向對象的解決方案和技術規範包括有、、、、、等等愈來愈多的系統採用基於技術的實現也成爲人們主要的選擇。然而隨着軟件系統的用戶需求的不斷髮展日益顯出了自身的不足。技術中最重要的概念是類和對象。類對數據及其相關操做進行了封裝封裝帶來了隱藏實現細節的好處但同時也限制了設計開發的靈活性和系統的擴展性。只能從業務流程的單一方向設計和實現系統而實際應用系統中業務繁多不少業務都須要執行共同的操做。日誌就是一個典型的例子基於傳統實現的系統會出現日誌相似操做的相關調用代碼分散在程序中多處引發代碼混亂對系統維護和理解形成較大困難同時也增長了開發人員額外的負擔。這種www.docin.com北京交通大學碩士學位論文第一章緒論編程模式還使得在多個類的方法中擴展相似操做變得很是困難喪失良好的擴展性。針對編程模式的不足人們提出了面向方面編程簡稱它把實現相似日誌這樣的操做看做一個橫切面利用能夠很好地解決這種橫切問題被不少人看好認爲是繼以後計算機編程學上又一場重大的革命力求站在一個更高的角度分解應用系統更接近真實世界架構系統解決所處的困境。研究及其應用現狀概念最早是由領導的施樂公司帕洛阿爾託研究中心即屺一個研究小組於年提出並隨後又申請了的專利。可是思想產生已經有至關長的時間了早在年開始觚屺的研究人員就對面向對象思想的侷限性進行了分析造成了概念的雛形甚至還有其餘人聲明更早的時候就作過與相似思想和方法論的研究如於年發表的論文中提到不修改已有代碼如何擴展已有系統功能。隨着研究的深刻被愈來愈多的人關注一個項目組近年來也一直花大力量研究還有不少關於的開源項目獲得了的支持如目前最成熟技術—一語言也獲得了相關項且組的支持公司也推出了他們的框架。目前和合併成了。也引發了微軟公司至關大的關注他們也正在加大力量對進行研究甚至在體系中已經不一樣程度應用了相似的思想。正在逐漸造成一套完整的程序設計思想各類平臺的技術也應運而生。平臺是應用最先的也是目前運用最爲成熟的出現了不少支持的框架如、、和基於的擴展語言這裏列舉的四種工具都是基於的實現它們被公認爲是走在的最前列。然而做爲一種新的編程思想和模式仍有待進一步探討web
研究基於設計開發的相關理論目前也很欠缺的具體實現技術還有不少不成熟的地方更沒有一個真正的語言全部這些致使距離普遍應用仍然有至關大的距離。www.docin.com北京交通大學碩士學位論文第一章緒論大多數應用仍然處在實驗研究階段僅僅是做爲一個輔助工具在被使用在系統開發中的應用也很是有限大多數系統都只是應用工具提供的框架實現解決了某些特定的功能。如企業項目中普遍採用的框架利用框架中提供的功能實現了事務處理與商業業務邏輯的分離。本文研究重點本文將與思想進行對比研究分析它們之間的關係對基於思想的設計和開發作進一步的探討和研究並分析了系統的特色基於模式從新設計架構系統研究系統中具備共性的一些橫切關注點利用語言設計實現基於模式處理這些橫切關注點的方案。本文結構安排本文共分爲如下五章第一章是緒論部分主要介紹了選題背景及其意義分析了當前主流編程範型模式的侷限性介紹本文的研究對象及其研究和應用現狀並提出了本文的研究重點和研究方向。第二章是本文對的理論探討研究部分主要闡述了思想及其相關概念分析了模式與模式的關係探討了技術實現原理對設計開發理論作了進一步的探討和研究。第三章基於技術設計分析系統架構的特色遵循多層架構、設計了一種系統架構分析了系統中一些具備共性的、重要的橫切關注點數據庫鏈接維護、對象持久化、緩存、權限認證及它們與系統各層之間的關係。第四章是本文的設計實現部分結合第二章對理論的研究基於第三章架構設計和橫切關注點的分析採用基於的擴展語言——對緩存、對象持久化、數據庫鏈接維護包含事務處理和權限認證幾個橫切關注點給出了模式的設計實現方案。第五章與傳統模式的系統架構進行對比分析了基於模式架構系統的特色突出顯示了在耦合性、可讀性、可擴展性三個方面的www.docin.com北京交通大學碩士學位論文第一章緒論優越性同時也提出了基於設計開發中一些不足的地方結合本身實驗體會列舉了一些最佳編程實踐條款。最後是本文的總結總結一些優點而且提出了進一步研究工做www.docin.com北京交通大學碩士學位論文第二章設計、開發研究第二章設計、開發研究基本概念發展至今並無在業界造成統一的認識目前也沒有一個確切的定義儘管如此已經顯示出了它強大的優越性。的目的是克服的不足實現系統更好的解耦從一個更高層次更天然地構建系統提升開發效率增長系統的可維護性和可擴展性。的不足就在於類對數據方法的絕對封裝性所帶來的限制針對實際應用系統中存在着大量的相似於日誌這樣的橫切面這種限制使得很難爲多個方法統一進行維護和擴展。而利用一種「橫切」的技術剖開類中封裝的多個方法能夠靈活地對這些方法進行切入新的業務代碼、擴展新功能點同時在具體開發實現時不須要對原有的類代碼做修改正如所提到的從外部往類中的方法批量擴展新的功能點而不用修改原有的程序代碼。以日誌操做爲例能夠用圖表明面向對象編程的實現圖表明的實現方法包含日誌操做調用日誌操做方法核心業務邏輯裏查墨堡圖面向對象編程實現模式日誌操做方法廠———經過相關技術日誌邏輯二百而牙西痙一方法方法包含日誌操做調用核心業務邏輯圖面向方面編程實現模式從兩圖的對比能夠看出面向對象編程從單一縱向構建系統圖中方法和方法代碼中須要顯式地包含對日誌邏輯操做方法的調用一旦相似業務方法數量龐大將致使日誌調用相關代碼分散在程序中各處產生混亂而在面向方面www.docin.com北京交通大學碩士學位論文第二章設計、開發研究編程模式中增長了一個橫切面從縱橫兩個方向分解系統圖方法和方法再也不須要顯式地調用日誌操做日誌操做由相關技術自動織入其內能夠認爲面向方面不只僅封裝了日誌操做的實現邏輯並且也封裝了對日誌實現邏輯操做的調用相比之下面向方面劃分系統更加天然系統耦合性進一步下降。在概念產生和發展的同時產生了一些新的術語關注點如圖中所示日誌邏輯和核心業務邏輯等這些功能點稱之爲關注點每個關注點都是咱們須要關心實現的一個邏輯功能點。其中核心業務邏輯這些關注點是實現主要業務邏輯的核心操做稱之爲核心關注點而相似日誌邏輯這些關注點它經過相關技術「橫切」織入程序中各個須要它的地方稱之爲橫切關注點。鏈接點圖中方法和方法須要切入日誌操做的地方都是鏈接點它是程序中一個精確的執行點。方法體調用或者執行、對屬性賦值或者讀取等代碼處均可以看做鏈接點可供織入橫切關注業務邏輯鏈接點爲提供了系統功能擴展的空間。通知包含橫切關注點的業務邏輯模塊能夠定義爲一個通知通知中還定義了橫切關注點和核心關注點切入關係、如何組合實現完整的商業業務邏輯。從不一樣的角度對通知能夠做出不一樣的分類一般根據切入方式和切入位置分爲如下三種前通知、後通知和周圍通知在本文第四章中都有具體的應用。切入點就是定義一個由此點切入一些具備共同特徵鏈接點所組成的集合橫切面這些鏈接點都須要切入同一個橫切關注點的業務邏輯。一個大的軟件系統中一般有不少不一樣的橫切關注點分別對應不一樣的橫切面面向方面編程須要爲每個橫切面定義一個切入點定義切入點的關鍵就是精確捕獲橫切面對應的全部鏈接點。方面切入點和對應的通知結合在一塊兒就是方面面向方面中方面的概念和麪向對象中類的概念很相似類是封裝模塊化了屬性及屬性相關操做而方面是封裝模塊化切入點及切入點處被切入的通知。甚至在語言中方面實現代碼形式也跟類的很類似但方面是從類外面實現對類中方法的擴展在方面內部實現對橫切關注點業務邏輯的調用同時描述了橫切關注點與核心關注點的www.docin.com北京交通大學碩士學位論文第二章設計、開發研究切入關係。另外∞還容許方面跟類同樣定義屬性和方法在本文第四章的具體實現中將會看到不少這樣的應用。織入將橫切關注點與核心關注點按照方面的定義進行組合成完整的業務邏輯這一過程在中稱爲織入。不一樣實現技術和不一樣織入需求織入過程能夠在不一樣的階段完成編譯以前、編譯之時、運行之時。上下文主要是指核心關注點方面鏈接點處一些信息一般指核心關注點業務方法的調用實例、方法名、調用執行的實參等這些信息一般會被橫切關注點切入時得到以供在通知中實現橫切關注點的業務邏輯。圖術語示意圖以上術語基本獲得業界的認同基於這些術語的技術特徵組成了最基本的技術當前絕大多數具都實現了這些技術。語言對語言作了一些擴展在新的語法要素中幾乎能夠找到與這些術語一一對應的的元素。與關係的介紹面向對象編程是當前主流編程範型是編程學上的一次意義重大的革命面向對象技術將現實世界問題領域與軟件編程中對象進行映射對現實世界中的www.docin.com北京交通大學碩士學位論文第二章設計、開發研究問題進行分解、簡單化使之符合人類的思惟習慣可以天然的表現現實世界中的實體和問題面向對象編程在軟件編程學上具備重要的意義。相比之前面向過程語言面嚮對象語言具有不少新的特色人們利用面向對象的封裝、繼承、多態思想能夠更加有效、天然地構建複雜的軟件系統。的優點相比傳統編程方法主要體如今如下幾個方面高度重用性。面嚮對象語言利用類封裝了數據和相關業務操做實現了良好的模塊化提升了系統代碼的重用性「對象模型的使用不只鼓勵軟件的複用並且還鼓勵整個設計的複用同時也致使可複用應用框架的創建」。面向對象編程使得系統帶來很大的靈活性。代碼結構的改良。因爲類的高度模塊化和良好的封裝性「類是理想的模塊化機制它的獨立性好修改一個類一般不會引發軟件的總體變化每每只需對局部做一些修改」。由此帶來一系列的好處耦合性下降、代碼易於理解、可維護性和可擴展性加強、易於測試和調試。、較易開發大型軟件產品。面向對象編程不只有利於實現複雜系統的細化並且也有利於團隊分工、共同合做許多軟件開發公司的經驗都代表當面向對象方法學用於大型軟件開發時軟件成本明顯地下降軟件的總體質量得以提升。然而發展至今也暴露出了思想的侷限性因爲類固有封裝特性忽略了類與類之間、方法與方法之間一些共同的實現細節橫切關注點在面臨這些問
題時會致使相同的代碼片斷分散在程序中各處形成代碼糾結在大型的企業應用系統中尤其明顯。面向對象編程的發展歸納起來經歷了三個階段第一階段以類爲中心設計開發利用類的封裝性和繼承性很好地實現了系統代碼複用性第二階段以接口爲中心能夠稱爲面向接口的開發更注重系統的耦合性第三階段以設計模式爲
中心基於組件的開發進一步提升整個系統設計的複用性。儘管如此面嚮對象語言仍然沒法完全擺脫在解決橫切關注點時的困境。是的補充和發展就是針對的思想侷限性設計出的一種新的編程模式是對技術的補充和發展。它與追求的共同目標都是實現軟件進一步解耦、提升軟件
複用性、增長軟件的可擴展性減輕開發者負擔、提升開發效率。注意到軟www.docin.com北京交通大學碩士學位論文第二章設計、開發研究件系統需求中存在大量的橫切關注點而解決橫切關注點問題時卻陷入代碼
混亂的尷尬處境只能封裝橫切關注點的業務邏輯實現而有關橫切關注點的調用代碼卻會分散在程序中各處分散了核心業務開發人員的精力和注意力不只增長了開發人員的負擔並且對系統各類性能也形成較大的損傷。不只僅封裝了橫切關注點的業務邏輯實現並且還封裝了對它的調用有效地實現橫切關注點與核心關注點的解耦提升了程序的模塊化程度。與現有技術不是一種競爭關係而以及相關技術爲基礎才能實現的開發模式。有了這一新的思想工具並不意味着對開發人員的面向對象編程要求能夠下降相反很是依賴於編程模式中良好的編程習慣這比如在開發模式中實現類的方法時仍然須要遵照結構化編程模式。思想模式並非萬能的它並不能解決開發中全部的問題可以很好解決的問題強行追求的實現每每只能是弄巧成拙。對的發展着重體如今對軟件系統需求層次上的劃分是從單一的縱方向構建軟件系統「一切皆爲對象」開發者用一組實例以及這些實例之間的關係組合構建軟件系統實例的組合按照業務流水單一方向進行。而注意到了系統中另外還存在不少「橫切面」增長了從橫方向構建系統這不只大大下降了系統耦合性並且能夠很是方便開發人員對系統功能進行擴展在不影響現有代碼的狀況下經過增長新的橫切面就能夠實現。將使得開發者能夠將應用需求更天然地映射到編程模式之中。對封裝性的影響經過定義類來增強系統的封裝性隱藏實現細節就是爲了對系統進行更好的解耦而橫切關注點是模式中被封裝的實現細節中共同的部分模式的封裝致使放棄了對這些橫切關注點的模塊化。採用「橫切」技術切入中類的方法爲開發人員提供了破壞面向對象中類固有封裝性的機會然而開發人員利用切入方法內部時只要運用恰當相反能夠帶來更好的封裝性正如所言「我相信應該作的是給程序員提供能寫更漂亮的程序的工具而不是施加足夠的安全機制讓他們不能編寫糟糕的程序」。模式就是這種提供更好的模塊化程序的工具。應該注意到模式中多個方法都封
裝包含對橫切關注點的調用並不合適這樣的封裝會引發代碼混亂的目的www.docin.com北京交通大學碩士學位論文第二章設計、開發研究正是打破這種不合適的封裝將對橫切關注點的調用封裝在「方面」裏面將被封裝的實現細節的共同部分抽離出來實現更好的模塊化下降系統耦合性。從某種意義上來講封裝了系統的靜態部分封裝了系統的動態部分。所以單純討論是否破壞的封裝性並無什麼意義中方法的絕對封裝有着它固有的思想侷限性而加入卻能夠使系統的封裝性作得更好。與設計模式的關係設計模式是面嚮對象語言開發經驗的積累各類不一樣的設計模式都定義瞭解決某一類問題的一種較好的策略著名的《設計模式》對設計模式作了概括和總結它不只提供了更好的設計方案並且還提供了基於面向對象軟件設計交流的工具。設計模式經過最大程度地利用面向對象的特性諸如利用繼承、多態對責任進行分離、對依賴進行倒置面向抽象、面向接口最終設計出靈活、可
擴展、可重用的類庫、組件乃至於整個系統的架構。在設計的過程當中經過各類模式體現對象的行爲、暴露的接口、對象間關係、以及對象分別在不一樣層次中表現出來的形態。然而鑑於對象封裝的特殊性「設計模式」的觸角始終在接口與抽象中大作文章而對於對象內部則無能爲力。並且因爲設計模式過於依賴接口和追求抽象與實現的分離有時會給人帶來設計的兩難抉擇簡單實現或者靈活設計。是對設計模式的延續突破了對象的封裝將系統中不一樣的關注點分爲核心關注點與橫切關注點並將之映射成面向方面的一種編程方式。並不須要藉助接口和抽象而是利用橫切技術直接深刻到對象內部截取方法之間傳遞的消息能夠隨意織入各類通知在不改變原有類的代碼基礎上實現該類功能的擴展。之因此較設計模式功能更增強大使用更加簡單關鍵就是在於設計模式是對面向對象編程語言的一種編程技巧而面向方面思想是對面向對象思想的進一步發展模式更接近現實世界構建系統。技術實現原理目前沒有純粹的語言絕大多數的工具和擴展語言都是基於面向對www.docin.com北京交通大學碩士學位論文第二章設計開發研究象語言的擴充在領域實現主要有兩種方式動態代理實現和基於面嚮對象語言的擴展。動態代理實現標準類庫包中有代理類和調用處理柄接口類中提供了方法。該方法能夠產生一個代理實例而且代理實例與被代理實例具有相同接口被代理實例就是核心業務方面的實例所以動態代理實現都要求爲全部核心業務類定義相應的接口。二者的代理關係經過實現接口的方法來肯定在覈心業務實例被代理的時候能夠實現切入橫切業務邏輯還能夠攔截核心業務邏輯的執行同時方法中的參數也爲切入時捕獲核心業務方面上下文提供了條件。這些具體實現一般封裝在一個工廠類中程序中須要新建核心業務實例時由該工廠提供一個代理實例。廠的實現代碼示例以下利用的代理機制獲取代理對象。代理對象與被代理對象具有相同的接口其中實現了接口示例代碼以下】恤www.docin.com北京交通大學碩士學位論文第二章設計、開發研究。髒方法調用前能夠切入相應橫切業務邏輯還可攔截核心業務邏輯地執行」核心業務方法執行以前能夠切入橫切業務邏輯」調用核心業務邏輯方法在方法調用後能夠切入相應橫切業務邏輯亂「舯」核心業務方法以後能夠切入橫切業務邏輯」
動態代理實現時捕獲上下文能夠在方法中進行方法有三個參數】分別暴露了核心關注點被調用方法的信息被調用方法所在的實例被調用方法被調用方法的行參列表。經過語句「」的調用執行核心業務中被捕獲的方法在該語句先後就能夠切入相應的橫切業務邏輯甚至不執行該語句實現攔截核心業務方法的執行。假定程序中有這樣的核心業務類及其對應的接口以下蛔」執行核心業務方法」測試代碼以下執行結果以下核心業務方法執行以前能夠切入橫切業務邏輯執行核心業務方法核心業務方法以後能夠切入橫切業務邏輯下圖描述了動態代理機制實現原理www.docin.com北京交通大學碩士學位論文第二章設計、開發研究核心豁垂務盍一一一一一一一一…一…一一一‘經過獲取接口類型的代理對象被代理實例爲類的實例■………………一圖動態代理實現原理圖動態代理實現機制基本上都利用了這一原理並配合文件的使用同時利用的反射機制提供了一個框架。這種實現機制最大優勢在於不須要額外的編譯器和新的語法學習、、這幾種工具都是基於動態代理機制的實現然而在實際應用中存在如下問題因爲代理實例的引入增長了額外的類加載和對象的建立雖然各類框架都採起不少措施進行優化但對性能產生的影響仍是比較大。因爲大量反射機制的應用對程序的容錯和效率也形成了較大的影響。動態代理實例的產生須要爲原始類定義接口而且對象的產生必須經過特定的工廠產生同時還須要配置一些文件在文件中定義鏈接點的捕獲、橫切方式和切入粒度等等增長了開發者負擔在使用上不夠靈活功能也不夠強大。動態代理因爲利用反射機制方法來調用核心關注點方法沒法支持基於靜態方法的鏈接點捕獲。動態代理主要是對方法的代理沒法支持對基於屬性的鏈接點捕獲www.docin.com北京交通大學碩士學位論文第二章設計、開發研究在動態代理框架應用中框架是其中傑出的表明在企業應用中被普遍採用提供了一個輕量級的容器能夠用來管理業務對象在框架內能夠很方便地實現面向方面事務管理使其與核心業務邏輯分離。另外還有一種實現的方法就是利用班庫利用它的代碼加強功能能夠動態地爲中的類生成子類實現原理基本相似只是這種實現方式能夠再也不依賴接庫在框架中實現對象持久化操做有不少應用在後續章節將做進一步的介紹。。基於面嚮對象語言的擴展語言是基於面嚮對象語言的擴展在語言基礎上增長新的關鍵字來實現技術如方面、切入點、前通知、後通知、周圍通知等等提供專用的編譯器來時識別這
些新語法要素在生成字節碼前編譯器修改須要被切入方法的相關源代碼從而實現「橫切織入」而後進行正常面嚮對象語言的編譯生成字節碼。的優勢很是突出這種相似預編譯的靜態織入方式徹底消除了動態代理機制對性能的影響。與代理機制實現相比不只能夠捕獲基於方法的鏈接點並且還能夠捕獲基於類屬性的鏈接點甚至還能夠很好支持基於靜態方法鏈接點的捕獲。同時因爲新語言要素的加入能夠很方便地定義切入點、通知等與思想術語相對應的語言成分利用新的關鍵字捕獲上下文也變得很是容易、天然可讀性也更好更加靈活地發揮了思想的功能特性。同時保持着原始語言的編碼風格開發人員很容易就能夠運用自如充分將面向方面編程思想應用到實際編碼中來。本文認爲是目前最接近將來純粹的語言已經被愈來愈多的人看做是事實上的標準也獲得愈來愈多技術的支持例如以上版本已經徹底集成了。固然也有它不足的地方因爲靜態式的織入每每一個橫切關注點橫切了多個類的方法程序中只要對代碼作一點點修改全部相關的源文件都須要從新編譯在實際應用中也會帶來一些不便。有關的一些語法特色在本文後續章節具體設計實現中還有進一步的介紹。須要說明的是的技術實現並非本文的研究的重點可是任何一種新的www.docin.com北京交通大學碩士學位論文第二章設計開發研究理念在其產生早期技術實現都很是重要。做爲一種新的編程思想理念非
常須要技術實現的支持好的技術實現有利於理念的推廣「理論與實踐相結合」使其在實踐中不斷地發展和完善。設計開發探討與研究基於面向方面需求分析面向方面編程核心思想就是分離核心關注點與橫切關注點實現分別專一這兩個方面編程對軟件需求的深刻理解是軟件開發得到成功的前提條件面向方面的需求分析重點是對用戶所關注的邏輯功能進行分類並分別映射到中的核心關注點和橫切關注點。如何將業務流程中主要業務流程同它的分支流程、非核
心業務功能分離開來分別做爲核心方面和橫切方面並明確它們之間的橫切關係。有關這方面的理論目前正在不斷的發展和完善之中和合著的—提出了基於用例圖分析和合著的—提出了一種方法進行分析與設計。基於的設計開發權限認證、事務、日誌等等已經廣泛被認爲是軟件系統中橫切粒度很大的系統級橫切關注點根據系統實現的具體業務功能每每還
存在各類粒度不一的業務級橫切關注點面向方面需求分析關鍵就是在需求階段
儘量地識別出各類關注點分離系統的橫切方面和核心方面將整個應用系統進行面向方面的模塊劃分下降整個系統耦合性減小設計開發的難度。將原始需求信息比做一束光束那麼識別關注點識別過程能夠用三棱鏡法則來形容穿越三棱鏡的光束需求信息通過三棱鏡折射關注點識別照射出來不一樣顏色的光束關注點實現基於面向方面的需求分析以下圖所示www.docin.com北京交通大學碩士學位論文第二章設計開發研究圖關注點識別三棱鏡法則設計層次良好的架構實現核心業務流程分離出去橫切關注點業務邏輯後能夠專一核心業務流程進行架構設計和編碼架構設計的層次性和編碼的規範性很大程度上影響「橫切織入」的複雜度。核心關注點方面業務流程仍然是系統設計的重點在系統中一般採起基於模型一視圖一控制多層架構在業務層根據業務的複雜度還可能再分層這種多層的架構不只下降了系統的耦合性和複雜度並且也很是有利於對不一樣層的代碼切入不一樣的橫切關注點通常來講不一樣的層都有它不一樣的「橫切面」如權限認證一般做爲控制層的橫切面而事務處理做爲業務層的橫切面。傳統的面向對象設計一般還會增長不少接口來進一步解耦層與層之間的關係、增長系統的靈活性和擴展性思想並不依賴接口它提供了新的開發模式和語言工具使系統設計和開發更加靈活同時能夠在不改變原有代碼的基礎上增長橫切面利用「橫切」技術自動將新的功能切入系統中提供一種全新的系統擴展方法。所以能夠對傳統的接口設計做必定的簡化力求系統架構清晰簡潔。定義切入點切入點定義了供通知切入的一批鏈接點鏈接點的數量決定了橫切粒度每個鏈接點都是系統的功能擴展點針對某一個橫切關注點如何準確的捕捉須要將其切入的全部鏈接點是定義切入點的關鍵。中同時支持基於方法和屬性的鏈接點捕獲一般主要根據如下幾種方式進行捕獲。在中主要是根據方法和屬性原型定義的特徵定位相應的方法或者屬性。方法原型名稱格式爲「訪問修飾【】返回值類型包名類名方法名形參www.docin.com北京交通大學碩士學位論文第二章設計開發研究列表」屬性的原型格式「訪問修飾【】類型包名類名屬性名」。經過對它們的匹配捕捉方法的調用、執行和屬性的讀取不一樣的具可能採用不一樣的匹配技術中使用了正則表達式進行匹配而語言中定義了三種專用的通配符’表明了除‘’以外任意字符串‘’表明了任意字符串包括‘’字符‘’表明了該類及其全部的子類Ⅱ中還提供了特殊的關鍵字來匹配構造函數。面向對象中的方法有兩種狀態方法的定義和方法的被調用根據這兩種狀態分別定義了兩種鏈接點在方法體的首尾進行切入編譯器能夠直接批量修改被捕獲的方法體代碼該方法一旦執行就會自動調用橫切業務邏輯在方法被調用的時候在調用處前、後進行切入橫切業務邏輯編譯器會在被捕獲的調用處先後加入相應橫切代碼。這兩種切入方式均可以攔截被捕獲業務方法的執行。面向對象中對屬性的操做有兩種讀取和賦值根據這兩種操做也分別的定義了兩種鏈接點捕獲對屬性的讀取操做捕獲對屬性的賦值操做。方法、屬性被調用處所在代碼即方法被調用或者被定義、屬性被讀取或者賦值時所在類名含包名或所在方法名中提供了和兩種關鍵字分別定義這種匹配。一般和配合使用。中提供關鍵字和定義調用流程之間的關係所謂流程關係例如方法的方法體中有調用方法就認爲執行的流程中存在對的調用不只類的方法中存在流程關係方面各個切入點也存在流程關係。和的區別在於鏈接點自身是否處在本身的流程中。利用切入點的流程關係能夠定義當同一鏈接點被不一樣切入點捕獲時的橫切業務邏輯的切入順序還能夠控制嵌套切入。將以上各類匹配特徵進行邏輯組合實現更加靈活的匹配方式語言中利用與、或、非三種邏輯操做符進行組合匹配。一個好的編碼規範對鏈接點的捕獲頗有做用特別是系統架構層次的劃分和類www.docin.com北京交通大學碩士學位論文第二章設計、開發研究所在包的組織及各類包名、類名、方法名的命名方式。組織核心關注點與橫切關注點的上下文橫切關注點與核心關注點業務邏輯在代碼實現形式上徹底分離經過「橫切織入」將它們組合在一塊兒實現完整的業務流程因此橫切關注點方面就須要得到核心關注點方面上下文才能共同處理流程中的數據信息。方法調用的鏈接點上下文主要爲被調用方法所在的實例、方法的參數、方法名和方法返回值等等。通知中實現橫切關注點業務邏輯處理的數據都是正對這些上下文信息在中提供了和關鍵字能夠在定義切入點的時候將方法的實例和參數顯示的暴露給橫切方面在通知實現代碼中還能夠得到函數返回值另外在通知體中還提供了關鍵字該關鍵字的兩個方法和能夠分別獲取被調用方法的名稱和全部實參列表。另外還能夠利用模式在橫切方面和核心方面之間傳遞上下文信息。中類實現了模式定義一個變量就能夠實現以當前線程爲關鍵值保存各自的數據信息。在系統中用戶每一次請求提交服務器端都須要完成一個完整的流程控制層接收請求、調用業務層處理相關業務、業務層鏈接後臺數據庫進行處理返回處理結果給控制層、控制層將
處理結果交予顯示層對用戶做出響應。流程之中存在各類鏈接點須要切入橫切業
務邏輯而在用戶的一次會話期間整個完整業務流程中無論系統執行核心業務邏輯仍是橫切業務邏輯絕大多數都是在一個線程之中根據這一特色利用變量就能夠很方便在覈心方面與橫切方面之間進行數據傳遞在本文的設計實現中多處使用了該類型變量在橫切方面中實現上下文的捕獲。www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析第三章系統架構設計與分析系統架構設計原則在基於的系統架構設計中有許多好的原則可供遵循在本文的設計中一樣遵循着如下一些設計原則多層架構原則。將業務與數據、現實分離下降系統的耦合性系統一般都採用基於的多層架構各層都對其餘層隱藏本身的實現細節儘量隔離複雜性。簡單原則。若是能用的工做完成的工做則選擇較簡單的解決方案。系統分層的過多也會帶來實現的複雜性一些重量級的組件不加選擇地使用也會增長系統實現難度、減小系統的可維護性沒有充足的理由就不要使用。模塊化原則。「模塊化是被分解成具備內聚性但鬆散耦合的模塊的系統特性」模塊化對提升系統重用性的具備重要意義能夠加強系統的可讀性和可維護性。在設計和實現中咱們會做不少工做來達到更好的模塊化。總體架構設計系統愈來愈多地應用於大型商業領域中業務複雜系統極爲龐大人們更加註重追求系統進一步解耦、提升系統的可維護性和可擴展性。系統的運行模式通常爲基於客戶端向服務器提交請求由服務器端負責全部業務處理、訪問後臺數據庫而後對用戶做出響應服務器端集中了幾乎全部的業務邏輯客戶端一般只負責顯示功能習慣稱之爲瘦客戶端所以系統架構設計集中在服務器端邏輯設計。本文基於技術探討設計系統的架構是針對在企業應用系統的一套完整的技術規範圖是標準模型。www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析圖標準模型標準模型規定使用作爲業務處理組件充分體現了在併發、分佈式計算上的能力但自己使用過於複雜用作業務處理過於死板定義的標準確實很強大不少子標準制定得很是出色可是同時也很複雜總
是顯得過於臃腫結構笨拙實用性也較差反卻是非標準的模型比較有影響力這一領域一些開源項目佔據了主流位置。面向對象技術已經至關成熟並且穩定人們在面向對象編程開發實踐中積累了不少寶貴的經驗總結出了大量實用性很強的設計模式本文基於技術構建的系統遵循的多層結構進行架構系統如圖所示圖系統多層架構其中頁面負責客戶端瀏覽器顯示全部來自於客戶端的請求統一交由相應的控制器處理收集請求數據並調用業務層業務操做進行相應處理而後將處理結果數據經過對象轉發至待顯示的頁面頁面最後在客戶端瀏覽器進行顯示以響應客戶的請求。其中服務器端應用程序須要經過鏈接數據庫而業務層業務對象簡記爲並不直接訪問數據庫而是先由封裝數據庫鏈接在中www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析獲取數據庫鏈接實現讀取數據庫的各類基本操做實例讀取數據庫時先獲取一個實例經過該實例訪闖後臺數據庫。整個架構中核心方面流程如圖順序圖所示圈圉圈圖系統核心方面順序圖詳細設計分析數據層在數據層須要解決面嚮對象語言訪問關係型數據庫的問題創建映射是有必要的將對象語言訪問關係型一些複雜、繁瑣的操做封裝隱藏起來。映射就是創建起「關係數據庫中的表」與「面嚮對象語言中的值對象類」之間的對應關係值對象類∞簡記爲就是一個普通的類它只有屬性及屬性相應的和方法數據庫中每一條記錄都映射成一個實例數據庫中表的字段一般都對應到實例中相應的屬性。基於映射思想訪問數據庫時將針對記錄的基本操做增長、刪除、修改、查詢映射爲針對的相應操做傳統的語言使用也會做些改變表名由類名代替、字段名由屬性名代替。在的開源項目中已經有不少優秀的框架、工具實現了映射其中以框架應用最爲普遍很好地實現了映射封裝了數據庫鏈接提供了與相似的語言。能夠在等框架基礎上封www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析裝的實現除了封裝基本操做訪問數據庫之外還須要提供一些有關事務和數據庫鏈接維護的方法以下手斷是否擁有數據庫鏈接胴矢取數據庫鏈接關閉數據庫鏈接開啓事務提交事務回滾事務經過的封裝解決面嚮對象語言訪問關係型數據庫的問題隱藏了實現細節使得業務層與後臺數據庫迸一步解耦。中的這些基本操做方法供業務層實例調用簡化了業務層對數據庫的訪問。而在業務層集中了全部具體商業業務邏輯實現能夠對實例的各屬性值進行修改這些修改操做都須要對應到中對相應數據庫記錄的更新操做這一操做稱爲對象持久化操做。在中提供了方法由該方法封裝持久化操做邏輯。在業務層調用實例的方法修改實例的屬性值時就須要調用方法將修改後的值持久化到數據庫中傳統的實現代碼示例以下經過∞方法修改產品的名稱脯修改後的信息保存在數據庫中很明顯這樣作聽任了一個橫切關注點——對象持久化邏輯分散在程序中多處致使程序員會屢次調用這一操做同時還須要開發人員本身判斷是否須要進行持久化程序中有些實例並非由數據庫記錄映射而來的多是臨時新建的對象對於這些實例的修改不須要持久化無疑增長了開發人員的負擔。所以關於對象持久化方面的工做有必要將這一橫切關注點分離出來用方面封裝它的實現和調用。業務層業務層由實例業務實例組成在每個類中實現相關的一批業務操做如前文所分析每個類訪問數據庫都須要獲取一個實例經過www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析實例訪問數據庫。基於這一特色能夠爲全部的類定義一個父類業務層類圖以下圖業務層類圖中的屬性設爲保護類型能夠被它的子類使用。同時利用中的方法也實現了對實例的一些基本操做的公用方法能夠根據須要直接被控制層調用。控制層調用業務層中方法執行具體的商業業務一個完整商業務操做流程步驟一般以下獲取一個實例經過它得到數據庫鏈接開啓事務若是該業務操做不進行寫數據庫操做能夠不用處理事務執行具體業務邏輯捕獲業務邏輯執行是否有異常決定提交事務或者回滾事務絕大多數異常都不會進行錯誤恢復。關閉中的數據庫鏈接一般是將數據庫鏈接歸還數據庫鏈接池其中步驟、、、中數據庫鏈接維護包括事務處理是核心業務流程中的橫切關注點開發模式無論將它們放在層仍是業務層每個業務方法的調用或者執行都須要操做、提交或者回滾事務、關閉數據庫鏈接這些代碼片斷分佈在程序中的各處必然致使代碼重複、混亂加劇開發負擔。究其緣由就是思想在處理橫切問題上的侷限性本文第四章將設計實現基於的解決方案。控制層在控制層接收客戶端的請求根據請求信息調用業務層業務操做完成具體業務www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析流程而後轉發至頁面響應客戶端請求顯示給用戶處理結果。在控制層主要是控制器的設計和實現一般一個用戶請求會對應一個控制器或者控制器中的一個方法。在標準的技術中簡稱能夠充當控制器由的或方法接受用戶的請求並調用相應的業務層進行處理最後轉發至頁面因爲每個都須要在文件中做一些配置若是每個用戶請求都定義一個與之對應則會加大的配置規模這在一個大型的企業應用系統中是沒法忍受的。所以須要對此該層進行細化從新設計。在控制層至少作了兩件事地址解析找到對應的控制器處理請求控制器調用後臺業務邏輯返回處理結果。針對這一特色本文設計以下將控制邏輯抽取出來單獨定義實現控制類控制類中每個方法均可以對應一種用戶請求。因爲控制類主要是處理和對用戶能夠爲全部的控制類定義一個父類在此將它定義爲抽象類示例代碼以下卸
∞廒取用戶請求的對象默認控制方法定義一個類充當全部控制類的派發器負責地址解析經過反射機制產生控制器類並調用相應控制方法處理客戶端提交的請求對象這樣文件中只須要對該類作配置便可。如下是控制層的順序圖www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析圖控制層順序圖在各個子類中全部的方法也存在一個橫切關注點用戶的每個請求到達類方法在調用後臺業務邏輯以前都須要進行權限認證。當前不少系統中都利用過濾器來攔截用戶的請求進行驗證操做通常來講都能較好地知足實際應用需求但它仍然存在兩個問題效率很低全部的請求都經攔截過濾。可讀性較差橫切業務仍然與核心業務糾結在一塊兒。把權限認證做爲控制器類一個橫切關注點基於實現能夠提供一個更加清晰和高效的架構。訪問系統靜態數據一個大型的系統中業務操做複雜業務信息讀寫頻繁系統中仍然存在一部分數據信息是相對靜態的如業務基礎數據、國家地區城市、網站配置菜單、角色權限等信息這些信息變更不多可是讀取卻很是頻繁對於這一部分數據進行緩存減小對數據庫的訪問能夠大大提升系統的性能。本文的設計方案就是在系統中增長一些工具類專門實現讀取這些數據工具類中全部的方法都定義爲靜態的以便在頁面控制層中直接經過類名進行調用。在組織這些工具類時因爲工具類中的方法仍然是實現一些業務操做故將www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析它們和類放在同一個大包路徑下包裏建兩個子包和分別存放類和這些工具類。如圖●◆◆∞嘲◆圖靜態信息業務類圖對工具類中全部方法執行的返回結果進行緩存就能夠實現性能的提升很顯然「緩存」也是一個橫切關注點若是直接在方法中實現緩存一樣出現代碼重複增長開發人員負擔。橫切關注點與層的關係分析經過以上分析咱們肯定了有四個橫切關注點分佈在系統之中在系統層次設計實現中每一個層所在的包路徑都不同顯示層主要都是一些?文件在項目中一般直接放在程序部署的根目錄下本文爲這些文件統必定義包路徑包。控制層主要由一個類分發器和多個類控制器組成類所在的包路徑定義爲。類所在的包路徑定義爲控制層中全部的類都放在包下。業務層主要有兩種類靜態業務方法所在的工具類的包路徑定義爲而其餘業務對象類的包路徑定義爲。前者能夠調用後者系統訪問數據庫都須要經過具體的業務對象類的方法。數據訪問層經過封裝對面向對象語言對關係型數據庫的訪問隱藏映射的實現同時還須要在層定義各類值對象類供各層使用。圖是系統層和主要包的調用結構關係圖其中橫切關注點如圖中註釋部分所示www.docin.com北京交通大學碩士學位論文第三章系統架構設計與分析顯示層自控制層
留數據層圖系統各層、包之間調用關係圖中註釋部分標出了四個橫切關注點緩存、對象持久化、數據庫鏈接維護、和權限認證以及它們所須要切入的包。這些橫切關注點涉及系統中核心業務流程的三個層次控制層、業務層和數據層它們在開發模式下都解決得不太好。下一章本文將利用語言針對這些橫切關注點詳細設計基於的解決方案實現它們與核心業務徹底分離。印璺彳邕嬰www.docin.com北京交通大學碩士學位論文第四章的應用與實現第四章的應用與實現本章採用語言着重針對第三章分析的橫切關注點進行詳細設計與具體實現對基於思想的設計開發作進一步的研究。實驗環境的搭建開發環境的搭建本文實驗基本軟件、硬件環境爲操做性統專業版爲內存爲的的筆記本式計算機。軟件開發工具主要都是開源的以下面嚮對象語言版本爲在的網站能夠免費下載得到它的安裝程序目前最新版本是但企業實際應用中並無被普遍採用大多數仍然使用的版本。集成開發編輯工具在的官方網站能夠免費下載得到壓縮包解壓後就能夠使用不用安裝。不只開源免費並且功能很是強大提供了不少代碼輔助、跟蹤調試、項目管理等實用功能還有各種豐富的插件經過插件的擴展的功能將進一步加強使用更加方便。服務器採用的版本是的免安裝版的網站上能夠下載得到。配置很是簡單本文基本採用它的默認配置它對硬件性能沒有過高的要求經過的插件能夠和組合在一塊兒使用。數據庫使用的是免安裝版下載壓縮包後直接解壓運行系統就會在後臺啓動網絡服務同時下載最新的驅動在中經過就能夠訪問該數據庫。在不少方面較之前版本有了很大的改進。開發環境的搭建目前雖然沒有純粹的語言卻出現了不少工具和基於面嚮對象語言擴展的語言其中以基於的擴展最爲突出在使用上很是符合編碼習慣語言表達面向方面編程思想很是天然。利用預編譯www.docin.com北京交通大學碩士學位論文第四章的應用與實現實現了代碼的「橫切」織入無論在易用、效率、功能上都很出色已經逐漸被更多的人視爲的實現標準愈來愈多的人傾向於用描述的思想能夠很好將思想映射成具體的實現編碼。在的開發環境下搭建主要如下兩步編譯器的安裝本文實驗中採用的是當前最新的版本和合併後歸於基金下的項目。由和酬公司贊助添加了一系列特性以支持它的下載地址是一下載獲得一文件在正常環境下包的默認執行程序爲直接點擊該文件運行安裝安裝完畢後須要設置兩個環境變量在中添力Ⅱ在中添加插件的安裝插件須要和版本匹配本實驗中採用的下載的插件壓縮包爲下載地址一—。插件的安裝很是簡單解壓包獲得兩個文件夾和只要將這兩文件夾下的文件釋放到目錄中對應文件夾下便可。安裝好插件後的環境就能夠支持使用語言進行開發了除了原有代碼系列輔助功能還提供不少的輔助功能方便基於進行項目開發。如下的詳細設計開發都是在該環境下進行實驗和測試的。對象持久化數據庫設計分析及映射第三章已經分析對象持久化的操做主要在數據層數據層封裝面嚮對象語言對關係型數據的訪問實現細節。以一個論壇系統爲例數據庫中主要的表結構以下www.docin.com北京交通大學碩士學位論文第四章的應用與實現圖論壇系統主要的表結構這三張表將分別映射到面嚮對象語言中三個值對象類用戶表對應類帖子表對應類版塊表對應類。除了類與表對應類中也會有與表中每一個字段對應的屬性每個屬性都會有一組方法和方法。經過方法訪問值對象類的屬性值達到訪問數據庫相應字段的信息相應地對方法調用修改實例的屬性值時就會對應到對數據庫信息同步這一對象持久化操做如前文所分析是一個橫切關注點下面基於思想實現分離該橫切關注點與它的核心業務。橫切關注點業務邏輯設計分析分離對象持久化橫切關注點時須要解決如下問題只對從數據庫記錄中映射產生的實例進行持久化。系統架構中的已經封裝了面嚮對象語言對關係數據庫的訪問全部的實例都是經過中的方法獲取獲得所以能夠對全部的方法增長一個橫切關注點記錄全部由映射產生的實例藉以判斷程序中實例是否須要實例化。須要確保每一條數據庫記錄在用戶的一次會話中只能映射成一個實例所以用戶每次讀取數據庫須要檢查讀取的實例之前是否已經讀取過若是讀取過則須要對已讀取的數據與數據庫進行同步不須要再次映射產生新的實例只需返回已讀取的實例便可這一操做應該在經過鏈接獲取數據集映射實例時進行。一個好的映射框架都應該實現該功能。www.docin.com北京交通大學碩士學位論文第四章的應用與實現業務層可能會對實例進行多個屬性值、屢次的修改若是每次修改都更新數據庫進行持久化使得訪問數據過於頻繁並且低效對系統性能會形成較大的損害所以對實例修改的持久化操做應該放在事務提交以前統一進行儘可能減小對數據庫的訪問。綜合考慮上述第點和第點假設用戶在一次會話中兩次訪問數據庫獲取了同一實例若是在第二次訪問數據庫前修改了第一次訪問數據庫獲取的實例那麼第二次訪問數據庫將可能得到髒數據並且獲取實例進行同步第一次獲取的實例將會覆蓋對實例值的修改。所以持久化操做須要在實例值修改後下一次數據庫訪問以前進行確保訪問數據庫得到最新的數據。經過以上分析持久化操做方面編程須要在業務層捕獲兩類鏈接點調用類的各類方法訪問數據庫。在該鏈接點處切入的橫切業務邏輯持久化已經被修改後的實例同時記錄由映射新產生的實例調用實例的方法。在該鏈接點處設置標誌實例相應字段已被修改。另外在業務方法執行完畢進行事務提交以前也須要檢查是否還有實例須要持久化下面章節中會討論事務處理橫切關注點的實現在事務處理方面的通知體中加入持久化邏輯便可。數據結構設計經過節的分析對象持久化業務邏輯主要是記錄全部映射產生的實例並同時記錄程序中對這些實例所做的修改在適當的時候進行數據持久化操做。設計如下數據結構保存本次會話期間全部相關實例信息www.docin.com北京交通大學碩士學位論文第四章的應用與實現圖持久化數據結構圖在該數據結構中每一種類型的實例對應中的一條鍵值對的類對象爲鍵值又是一個對象。在值對象中的每個鍵值對記錄實例及其全部修改過的字段。基於該數據結構設計持久化操做類—如圖◆圖類圖該類中主要定義了一個靜態變量和三個靜態的公有方法因爲系統都是多用戶併發訪問對於每個用戶訪問服務器都須要保存當前線程地持久化信息所以定義變量該變量中存儲的對象即爲上文中卵對象。方法。記錄映射產生的實例若是該實例已經記錄則進行同步並返回該實例。方法。記錄某個實例已經被修改持久化操做會根據該修改狀況同步數據庫中對應的記錄。。若是存在實例有字段被修改拼裝語句進行對象持久化操做同時清除實例字段被修改信息。捕獲對類方法的調用定義切入點捕獲在業務層對類方法的調用在這些被捕獲的鏈接點處切入橫切業務邏輯在方法被調用前檢查是否有實例須要持久化調用執行完成後同步已有映射產生的實例保證同一次回話中每條記錄對應一個www.docin.com北京交通大學碩士學位論文第四章的應用與實現實例再一次記錄映射產生新的實例因爲鏈接點先後都須要切入橫切業務所以定義基於該切入點的周圍通知示例代碼以下定義切入點。’捕獲全部對類方法的調用。限定在業務層定義後通知腩全部已經修改過值的實例進行持久化同時記錄新映射生成實例該通知流程描述以下圖方面通知流程圖捕獲實例的方法在業務層類中捕獲實例的方法切入的橫切邏輯判斷實例www.docin.com北京交通大學碩士學位論文第四章的應用與實現是否來自數據庫記錄映射產生從而決定是否須要進行持久化操做。大體實現代碼以下定義後通知便可定義切入點曲?’。捕獲全部實例方法的調用限定在業務層廒取上下文實例定義後通知判斷實例來自數據庫記錄的映射決定是否記錄該實例須要持久化中的實現原理本人實際項目開發中幾乎都採用框架它很好地實現了映射的同時對持久化也作了不少工做較好地知足了實際應用需求所以在項目實施中持久化橫切關注點並無採用本文基於的實現方案。然而從以上分析和本人對代碼各個局部實驗測試來看該方案從映射中分離出持久化相關橫切關注點程序結構更加清晰、易於實現、減小了開發工做量。而框架因爲利用類庫爲類生成代理類加強了類中的和方法這也是一種基於代理機制編程思想。是一個強大的、高性能、高質量的生成類庫它能夠在運行期擴展類也能夠動態實現的接口類庫也是開源的項目。利用實現原理與基於中的類的實現很是相似只是它能夠再也不依賴接口直接利用類生成一個原有類的子類則原有類的每一個方法調用都會調用接口的】函數。在函數裏就能夠經過執行「」來執行實例原有的方法或者方法在該語句執行先後切入所須要的橫切業務邏輯根據須要甚至能夠不執行核心業務操做均可以。示例代碼以下www.docin.com北京交通大學碩士學位論文第四章的應用與實現生成的子類被回調接口的方法。【】」調用日誌方法」
利用類庫實現以上全部的實例都經過該工廠「方法建立得到則該實例的全部方法體中第一行都會被切入語句」調用日誌方法」同時接口方法的參數列表也暴露了核心業務數據信息能夠供橫切業務捕獲相應的上下文。正是利用這一原理動態生成實例並在其方法和方法中切入了持久化相關的橫切業務邏輯。另外在組織多個實例之間的關係時爲了提升性能還切入了對某些屬性延時加載的功能。數據庫鏈接維護橫切關注點分析數據庫鏈接維護是業務層中類的業務方法的橫切關注點業務層全部類都繼承基礎類。類定義爲抽象類在該類中實現了最基本、最簡單一些業務操做如向數據庫中添加一個實例、刪除一個實例、經過語句獲得列表等這些方法既能夠被業務層外直接調用也能夠在層類調用提升系統的靈活性。在的子類中實現一些具體業務業務層中的類的方法調用關係以下www.docin.com北京交通大學碩士學位論文第四章的應用與實現圖業務層類調用關係圖圖中利用表明各類不一樣業務類儘量體現業務層的各類調用關係將這些調用關係分紅三類業務層對本層外部的調用類依賴實例訪問數據實現商業業務方法業務方法中全部數據庫讀寫操做都須要藉助於中的方法所以須要調用類中的方法業務層被層外部調用在本文架構中只限於控制層和工具類中的方法對它們調用爲了提升業務層中方法的代碼重用性業務層內部必然也會存在相互調用的關係。全部的業務方法都須要經過數據庫鏈接訪問後臺數據庫都須要進行數據庫鏈接維護操做爲了提升整個系統的性能應該把中的實例設置爲延時加載避免沒必要要的實例的建立在須要使用它的時候才建立提升數據庫鏈接的利用率。所以建立實例應該是在類中對屬性讀取的時刻。www.docin.com北京交通大學碩士學位論文第四章的應用與實現當實例在包內互相調用時須要確保一次業務流程的執行只能使用同一個實例保證一次完整的業務處理中使用同一個數據庫鏈接所以還須要將建立的實例保存起來供當前線程公用在建立以前須要判斷當前線程是否已有實例從而決定是否須要建立。同時數據庫維護中還包含對事務的處理事務處理並非每一個業務方法都必須的只有當業務方法涉及「寫數據庫」操做時才涉及事務須要解決一個問題區別類的業務方法是否須要事務不少工具由程序開發人員經過定義文件對每一個類業務方法做一些事務配置由程序讀取配置文件決定是否切入事務。定義文件無疑增長了開發人員的負擔。對於事務處理的判斷本文給出另一種設計方案。分析類對數據庫的封裝業務層訪問數據都須要對通類的方法進行類中的方法是頗有限的並且比較固定那些須要寫數據庫的方法也是比較明確以下列舉的方法經過實例再數據庫插入一條記錄。經過實例更新數據中一條對應的記錄。。經過實例刪除數據庫中對應的一條記錄。和經過語句前者不帶參數後者帶參數寫數據庫和經過語句前者不帶參數後者帶參數寫數據庫一旦捕獲到以上這些方法的調用開啓事務並標記之再次捕獲時根據該標記能夠避免屢次開啓事務。在整個業務方法執行完畢後根據標誌決定是否須要做事務處理提交或者回滾同時關閉數據庫鏈接。另外在本章節討論了基於實現持久化方面的操做在實際應用系統都運用了框架已經作好了持久化這些寫數據庫操做天然也須要事務如何捕獲這些鏈接點中隱藏了這些持久化操做的實現沒法直接捕獲可是能夠捕獲對映射產生的實例的方法的調用一旦捕獲www.docin.com北京交通大學碩士學位論文第四章的應用與實現一樣開啓事務設置事務開始標誌。經過上述的分析有三類鏈接點須要捕獲在類中捕獲對屬性的讀取切入建立實例邏輯在類中捕獲對須要寫數據庫操做的方法的調用和對映射產生實例的方法的調用切入開啓事務邏輯在包外捕獲對類方法的調用切入捕獲異常決定是否提交事務或者回滾事務以及關閉數據庫鏈接。對這三類鏈接點及其對應的橫切業務邏輯分別定義方面進行實現。建立實例方面編程建立實例的流程以下圖所示圖建立方面橫切業務流程首先須要定義該方面的切入點捕獲全部的鏈接點在類中捕獲全部對屬性的讀取切入的橫切業務邏輯如圖所示須要判斷當前線程是否已建立實例而決定是否建立實例。所以一旦建立實例就使用中的變量保存起來在該方面中同時提供靜態方法得到該實例並將調用建立實例的邏輯也封裝在其中。定義方面示例代碼www.docin.com北京交通大學碩士學位論文第四章的應用與實現以下定義切入點定義前通知直接返回當前線程的實例’定義變量保存當前線程的實例腹淡取當前線程的實例硼從變量中獲取當前線程的實例若是當前線程沒有建立Ⅱ建實例變量中保存建立雕實例返回當前線程建立的實例
分析上述方面的實現代碼能夠看到屬性一直都沒有進行賦值並且通知也沒有的調用屏蔽了對核心業務中對屬性的讀操做通知體中採用了進行代替直接返回當前線程建立的實例供核心業務訪問數據庫全部中的屬性的做用已經失去了原有面向對象語言中屬性的做用在這裏它只充當了面方面定義切入點時一個供捕獲的特徵。可是方面
的切入對於面向對象實現核心業務編程卻徹底是透明的開發人員仍是能夠按照
原來的面嚮對象語言方式實現核心業務只是再也不受橫切業務的干擾。這是面向方面編程一個對面向對象比較完全的思想突破。開啓事務方面編程該方面編程須要捕獲的鏈接點對須要寫數據庫操做方法的調用和對映射產生實例方法的調用。前者本文已經分析就是中僅幾個有限的方法會進行寫數據庫操做捕獲這些鏈接點比較容易利用‘¨’操做組合分別對每一個方法的原型特徵匹配便可。www.docin.com北京交通大學碩士學位論文第四章的應用與實現對於捕獲調用實例方法的鏈接點因爲數據層使用了框架判斷實例是否由數據庫中記錄映射產生有兩種辦法框架將全部映射產生的實例都緩存在了中而且提供了可供調用。能夠捕獲全部的實例方法的調用而後判斷該實例是否在中從而決定是否須要事務。另外也利用庫加強了實例的和方法其實映射產生的實例都是類子類的實例這些子類都實現了一個接口。經過對捕獲這個接口的子類能夠過濾掉其餘的實例。本文選擇第種方式捕獲這些鏈接點。另外橫切業務一開啓事務在鏈接點處核心業務以前執行通知類型爲前通知定義方面示例代碼以下定現入點定義切入點’’。’’捕獲類有寫數據庫操做方法的調用’?‘一捕獲映射產生的實例方法的調用定義前通知膳《取當前線程的實例經過實例開啓事務’第三章節已經討論了在類中實現有關事務處理的方法其中方法封裝開啓具體實現細節確保一個數據庫鏈接中同一時刻只能開啓一個事務。www.docin.com北京交通大學碩士學位論文第四章的應用與實現關閉數據庫鏈接、結束事務方面編程本文設計的方案中關閉數據庫鏈接、回滾事務、提交事務的橫切業務邏輯都在中定義以下靜態方法封裝對其的調用進行實現關閉數據庫鏈接朦取當前線程的實例朕閉數據庫鏈接提交事務代碼省略回滾事務代碼省略後面兩個方法省去了具體實現這些方法供方面的通知體調用切入核心業務中。該方面須要捕獲的鏈接點從包外對中的方法的調用因爲全部的類都是在包下對業務方法捕獲將很容易如示例代碼。因爲包含事務處理須要對業務方法進行異常捕獲從而決定是提交事務仍是回滾事務所以定義周圍通知。定義方面示例代碼以下定義切入點’。匹配包下全部類公有方法的調用一’限定在包外的鏈接點定義周圍通知肌同用核心業務方法類的業務方法腱交事務回滾事務關閉數據庫鏈接’www.docin.com北京交通大學碩士學位論文第四章的應用與實現對與關閉數據庫鏈接的切入點考慮到控制層在一次用戶請求中可能須要調用多個業務層的業務方法在有些項目中會推遲一些可能在出控制層時才關閉數據庫鏈接避免實例頻繁地建立和銷燬。因爲採用面向方面編程這個修改將變得很是容易直接修改該方面就能夠實現而不用對核心業務代碼作任何修改充分體現了面向方面編程分離橫切關注點的優點。緩存橫切關注點切入點分析在包內定義工具類實現讀取系統中相對靜態的信息因爲這些信息讀取比較頻繁對這些信息進行緩存能夠減小數據庫訪問次數提升系統性能。所以緩存是這個包內全部公有方法的一個重要橫切關注點。緩存的切入點所要捕獲的鏈接點就是包內全部公有方法的執行在該鏈接點處將方法執行結果緩存起來當下一次發生一樣的調用時能夠直接返回緩存結果。在前面設計實現中都是使用捕獲對特定方法調用鏈接點這些方法主要集中在業務層和數據層如圖所示業務層和數據層的方法與頁面顯示層不存在直接的調用關係而頁面能夠直接調用工具類方法若是仍然使用進行捕捉他們的調用將會失敗當前服務器如、都是對即時編譯它們直接使用標準的編譯器編譯頁面生成的字節碼的類文件。所以的編譯器對頁面中的鏈接點再也不起做用須要使用另外一關鍵字捕獲工具類方法體中的鏈接點。同時工具類的方法中會存在內部互相調用的狀況須要解決嵌套緩存的問題以此提升緩存效率。中關鍵字能夠實現對循環切入的控制見節具體實現。緩存主鍵上下文分析如何判斷是否一樣的一次調用從而能夠利用上一次調用時緩存的結果關鍵是須要獲取鏈接點處的上下文以上下文爲主鍵進行緩存被調用方法的執行結果就能夠根據該緩存進行判斷是否有被緩存過的執行結果可直接被重用。工具類的公有方法都是定義靜態的所以該上下文主要有方法名含包名和類名、實參列表。在通知中提供的關鍵字中有兩個方法www.docin.com北京交通大學碩士學位論文第四章的應用與實現暑分別能夠得到這些上下文。以方法名和實參列表爲主鍵在緩存中存儲這些公用靜態方法的執行結果緩存數據結構設計以下圖所示圖緩存數據結構圖緩存由一個實例充當它的鍵值分別是方法名和一個實例亥實例存放的鍵值對是實參的特徵值與被調用方法的執行結果。實參的特徵值經過遞歸組合每個實參的哈希碼計算獲得這種算法與重載類時的方法的算法相似。具體算法以下’www.docin.com北京交通大學碩士學位論文第四章的應用與實現否圖組合算法基於這種數據結構設計的緩存同時也須要提供一些取值和設值的操做定義類封裝緩存數據及其相應的操做緩存類中提供的方法主要有獲取緩存數據判斷是否已緩存和緩存調用結果。類圖以下www.docin.com北京交通大學碩士學位論文第四章的應用與實現越塒定義埋存∞醴印◆氓往哈根據方法名和安’列衰獲取援存中的教撼’№硪鰣刪膪喇叼啪四∥根據方法名和參斂列衰爿斷是否已做垤存嘲報撼方法名和參數列衰援存調用結摹脯窯埋存圖類緩存方面實現以上分析了方面實現的的切入點和上下文以及緩存數據結構設計實現緩存方面的代碼以下定義切入點’塒’’定義周匿通知利用關鍵字防止嵌套緩存。蕨取上下文方法名。場【】威取上下文實參列表∥從緩存中獲取數據腳果已經緩存直接返回緩存的結果月用核心方面工具類方法將運行結果存入緩存區回運行結果該方面在程序上實現了緩存邏輯與工具類中的一些具體業務邏輯編碼徹底分離程序編譯以後將會向包內全部工具類的方法織入緩存邏輯。緩存的信息是相對靜態的也會有修改的時候所以須要考慮數據同步的問題因爲這些信息一般都是由系統的管理員進行維護本文在設計緩存類的時候提供了方法能夠供管理員從前臺發送請求調用清空全部的緩存保www.docin.com北京交通大學碩士學位論文第四章的應用與實現證數據同步。這種作法在實際項目實施中取得了較好的效果。緩存設計實現還有不少工做須要作清空全部緩存實現數據同步並非很理想應該由程序自動判斷緩存中不一樣步的數據只清空這部分緩存便可另外還應該對緩存內容的使用狀況進行監視設定合適時間內若是緩存內容沒有被再次使用就能夠清除該部分緩存以節省存儲空間。本文在此不作進一步分析了。權限認證控制層的權限認證採用基於角色的訪問控制方法它是目前公認解決大型企業的統一資源訪問控制的有效方法。其顯著的兩大特徵是減少受權管理的複雜性下降管理開銷。靈活地支持企業的安全策略並針對企業的變化有很大的伸縮性。數據庫結構設計權限認證主要有三張表用戶表、角色表、資源表。用戶表記錄系統中全部用戶基本信息主要字段爲用戶、用戶名、密碼等。資源表記錄控制層全部控制方法信息每一條記錄對應類中的一個控制方法主要字段資源、資源名稱等角色表根據不一樣用戶類型定義各類角色主要字段角色角色名稱等。每個用戶能夠對應多個角色一個角色能夠擁有多個資源權限用戶與資源不發生直接關係經過角色關聯本身能夠訪問的資源用戶表與角色表、角色表與資源表都是多對多的關係關係圖以下www.docin.com北京交通大學碩士學位論文第四章的應用與實現圖基於角色權限設計表關係圖基於角色權限設計方案根據實際須要還能夠加入羣表該表的記錄能夠與實際應用系統中用戶所在的部門組織相對應能夠實現批量爲用戶分配角色。權限控制邏輯詳細實現不是本文的重點本節旨在實現如何運用模式分離具體業務邏輯和權限控制邏輯。權限上下文分析客戶端請求提交給控制層在控制方法體中處理請求、調用具體業務邏輯以前都須要進行權限認證前文已經分析了權限認證邏輯實現經過模式分離出來單獨實現須要在切入控制方法體時獲取控制方法信息使其對應到資源表中的某一條記錄本文設計的方案就是經過的關鍵字獲取控制方法的全稱包名類名方法名控制方法都是不帶參數的而資源表的資源字段直接取值爲方法的全稱。具體實現權限部分數據信息相對於具體的業務數據信息來講是相對較爲靜態的在節設計的類增長方法調用層的業務方法∥判斷某個角色是否具有訪問該控制方法的權限在節中咱們已經實現了爲全部類中的方法切入了緩存業務邏www.docin.com北京交通大學碩士學位論文第四章的應用與實現輯這樣能夠減小權限認證邏輯對數據庫的訪問。在用戶登錄系統以後中保存用戶所擁有的角色用戶從客戶端提交請求到中的方法切入權限認證邏輯實現代碼以下定義切入點捕獲全部地控制方法胴浹取上下文空制類中方法的全稱從中得到用戶的角色信息調用。進行權限認證
一旦權限認證不經過核心業務就會被橫切方面攔截拋出異常轉向登錄的頁面。www.docin.com北京交通大學碩士學位論文第五章基於模式的系統特色分析第五章基於模式的系統特色分析在第三章本文給出了一種系統多層架構設計分析了各層須要切入的橫切關注點第四章針對這些橫切關注點已經設計實現了基於的解決方案。基於這種模式的系統與傳統的純模式的系統相比有了很大的改進採用純模式設計的系統各個橫切面業務邏輯與核心業務邏輯都糾結在一塊兒相同代碼片斷分散在程序中多處。以業務層流程順序爲例如圖圖面向對象的業務層順序圖從圖中能夠看出業務層類的方法除了實現核心業務邏輯之外還須要顯式地包含對輔助業務數據庫鏈接、事務處理等相關代碼的調用這種純的實現模式使得業務方法越多將會致使相似代碼片斷越多的分散。而基於本文
面向方面的設計實現方案徹底分離出了橫切方面單獨實現橫切業務邏輯利用橫切機制對全部的業務方法統一切入橫切方面業務邏輯自動組合實現完整的業務流程。橫切業務核心業務徹底處在兩個不一樣的方向上實現了完全的解耦避免代碼糾結。基於模式設計的本文方案業務層流程如圖所示www.docin.com北京交通大學碩士學位論文第五章基於模式的系統特色分析翌罌』庫鏈接、’翌罌庫鏈接心業務方法圖面向方面的業務層順序圖圖和圖的對比來看較從一個更高的思想層次構建系統模式實現更加天然、簡單更易於理解。的優點總的來講基於模式的系統相比傳統的模式優越性主要體如今如下幾個方面耦合性將系統分爲兩個方面核心關注點和橫切關注點從一個更高的層次對系統作了分解實現了核心業務與橫切業務的徹底解耦將類中實現細節的共同部
分抽離出來封裝在方面中單獨進行實現具有更好的模塊化。以數據庫鏈接維
護方面實現爲例在業務層與控制層徹底再也不關心數據鏈接的獲取和關閉在方面的通知中定義了數據鏈接獲取和關閉與核一業務執行的切入關係實現了任什麼時候候在控制層中調有模型層業務方法都會自動切入數據庫鏈接維護相關操做可是在編碼實現上又是徹底分離在方面中不只封裝了橫切業務邏輯的www.docin.com北京交通大學碩士學位論文第五章基於模式的系統特色分析實現並且也封裝了核心業務邏輯對橫切業務邏輯的調用使二者的耦合性大大下降。在本文的設計方案中雖然利用加入了各類實現橫切關注點的代碼但仍然保持核心業務多層架構特色橫切關注點方面的實現對於核心關注點方面徹底透明整個系統實現了更高層次的解耦。可讀性分離出橫切方面的業務邏輯以後使程序開發人員能夠專一核心業務編程再也不受橫切業務方面的干擾不只減輕了開發負擔還能夠編寫更加簡潔的核心業務代碼具有更好可讀性。以事務處理爲例傳統的實現都須要程序員對本身開發每個業務模塊進行操做決定是否事務回滾或事務提交操做增長了程序開發人員的負擔同時大量的非核心業務代碼影響了人們對程序的閱
讀和理解。而一旦將這些放在方面中實現核心業務模塊化大大增強核心方面業務代碼將再也不與非核心業務代碼糾結在一塊兒實現起來更加容易清晰。可擴展性可擴展性是思想一個最大的特點它爲系統提供了一個新的擴展機制能夠很是容易地在不修改已有代碼的基礎上實現系統功能的擴展。方面能夠在程序任何鏈接點處注入須要擴展的功能邏輯只須要增長有關方面代碼的實現便可這樣能夠推遲不少傳統設計上的決定。在此以性能監控功能爲例在一個系統部署運行初期一般都須要監控各個業務方法的執行性能狀況傳統的實現方式可能
須要在各個業務方法先後手動插入一些代碼目的達到以後爲了不對性能的影響又須要手動刪除這樣的作法對於一個大型系統是難以忍受的。可是利用就很是容易實現該功能的插拔定義如下方面便可定義周圍通知」」www.docin.com北京交通大學碩士學位論文第五章基於模式的系統特色分析在該方面的定義中重用了在關閉數據庫鏈接方面定義的切入點捕獲全部業務方的代用執行在其先後切入性能監控相關代碼。整個實現很是簡單。就像是在原有系統中只增長一個新類而已並且不用對原有代碼做任何修改。系統中不少須要擴展的功能均可以經過這種方式實現。良好的可擴展性同時也具有良好的可維護性面向方面編程將全部的橫切關注點集中實現和調用更加方便對橫切業務的維護。基於模式系統設計開發的不足做爲一種新的編程思想模式在進行系統設計開發的時候也存在一些不足的地方本文設計方案採用語言在環境下進行實驗不足之處主要體如今如下幾個方面的開源社區已經提供的插件在可視化設計和代碼輔助上作了很大的支持可是仍然存在不足特別是可視化在準確性和可用性上有些欠缺。另外缺少對橫切業務實現代碼跟蹤調試的支持。當前各類主流的服務器缺少對支持。利用語言在開發環境下編譯後的字節代碼在現有的服務器運行能夠不須要專有編譯器支持但在系統中全部頁面都是利用標準的編譯器即時編譯要想捕獲頁面上的鏈接點就沒法實現所以存在必定的侷限性。基於面嚮對象語言擴展的實現原理編譯器在源程序編譯生成字節碼以前會對源程序做一些橫切織入修改所以對方面織入的作任何修改相關涉及的類都須要從新編譯對系統部署形成一些麻煩。對編碼風格和編碼習慣的限制在編程中很重要的一點是如何定義切入點精確捕獲全部鏈接點爲了使定義切入點更加容易要求面向對象編程具有統一編程風格甚至須要強制些良好編程習慣如本文設計方案中對各層代碼所在的包路徑都作了嚴格的限制這樣才容易根據包路徑的特徵在不一樣的層中切入不一樣的橫切業務。定義切入點的時候大多數都須要根據對方法名的特徵匹配從而捕獲鏈接點所以對系統的代碼包的組織結構和調用關係都提出了強制性的要求例如在頁面www.docin.com北京交通大學碩士學位論文第五章基於模式的系統特色分析中就不能直接調用業務層的類的方法不然因爲頁面中沒有切入一些必要的橫切業務數據庫鏈接不會主動關閉事務結束也得不處處理從而致使出錯強制要求類的業務方法只能在控制層等地方被調用程序才能正確執行。另外並不支持對利用反射機制進行方法調用的捕獲所以試圖利用反射機制調用類的業務方法也會致使一樣的錯誤。相對於面向對象編程面向方面編程的確帶來了更多的代碼編寫限制可是這種限制也有利於幫助咱們開發出程序結構、代碼風格更加良好的系統正如的做者所言方面能夠用於維護一個類的幾個方法之間的內在一致性它很是適合強制一種按契約進行設計的編程風格能夠用於強制各類常見的編碼習慣。做爲一種基於語言的擴展語言雖然存在着一些固有的缺點可是總的來講目前它仍是功能最強大、使用最方便的具。面向方面編程最佳實踐語言做爲當前語言事實上的規範使用靈活功能強大更方便體現面向方面編程思想使面向方面編程更加天然。結合本文的實驗體會提出如下最佳實踐條款儘量爲一些具備相同性質的類定義簡單的父類父類最好定義爲抽象類或者接口這樣能夠很是方便根據父類對這些類中的鏈接點捕獲。如本文設計方案中對全部的業務對象類定義了父類。讓業務層與控制層、數據層完全分離保持單向的調用關係防止各層之間出現循環調用關係。例如一分開。各層都對其餘層隱藏本層的具體實現。禁止在和中實現業務邏輯。能夠使用模式來下降代碼的耦合度在橫切關注點與核心關注點之間傳遞上下文由於絕大多數用戶的一次請求都是在同一個線程中完成儘量在程序開發中嚴格遵循這一點不然須要做特殊處理形成一些麻煩。不要試圖用關鍵字捕獲頁面中對方法進行調用的鏈接點當前的服務器尚不支持只會致使失敗。變通的方法能夠採用關鍵字切入被調用方法體內部捕獲方法的執行。頁面中減小對後臺業務方法的直接調用儘量的從對象中獲www.docin.com北京交通大學碩士學位論文第五章基於模式的系統特色分析取數據。在本文設計方案中強制禁止頁面直接調用類的方法但能夠調用業務層中工具類方法。各類標誌符的命名遵循一些約定俗成的習慣包括方法名、包名、類名、屬性名等命名。這樣方便於利用專有的通配符根據這些命名特徵進行匹配從而更加容易捕獲鏈接點。例如全部的實例的方法都以「」爲前綴這樣就能夠很容易定義切入點切入對象持久化方面的橫切業務。www.docin.com北京交通大學碩士學位論文結論結論總結本文對設計與開發作了積極地探索和研究。介紹了的主要概念橫切面、切入點、方面等探討了有關技術實現原理和設計開發理論結合系統的特色設計了一種基於的系統的架構重點研究了在系統中的應用針對系統具備共性的橫切關注點對象持久化、數據庫鏈接維護、緩存和權限認證設計實現了基於的解決方案。從中咱們能夠看出相比傳統面向對象編程模式的優越性主要體如今如下三方面減小核心關注點業務開發人員的負擔使他們能夠專一商業業務邏輯的開發提升開發效率。同時有助於團隊成員之間分工協做因爲核心關注點和橫切關注點的完全分離團隊成員能夠分別專一於這兩方面開發互相影響大大減少有效發揮團隊力量。有效解決了模式下面臨「橫切」問題時的代碼混亂使系統進一步解耦加強了系統的可讀性、可維護性和可擴展性利用能夠在不修改系統核心方面代碼的基礎上只需增長「橫切面」就能夠很容易實現系統功能的擴展。不只很好的解決系統中已有橫切關注點與核心關注點的分離也爲之後系統增長新的橫切關注點擴展新的功能提供了更大空間同時對已實現橫切功能維護變得很是獨立。從單一的層次方向構建系統而增長了橫切面方向從一個更高的層次構建系統更天然地將系統需求分析映射到編程模式更加方便人們對系統的設計、開發和理解。進一步工做做爲一種新的編程模式仍然處在不斷髮展和完善之中當前設計、開發、測試理論仍然至關缺少在業界缺少統一的規範甚至還存在對它的種種爭論在實際應用中還沒有出現真正的語言。在一個新的編程思想沒有成熟之
前將更加吸引着人們對這些問題的探討和研究。在理論和實踐應用方面都www.docin.com北京交通大學碩士學位論文結論有待進一步的探討研究實踐應用中增強在具體商業業務領域的運用目前大多數的應用仍然侷限於解決一些系統級橫切關注點問題須要擴大的應用領域在應用中不斷總結經驗發現的規律充實相關開發理論。目前無論是基於動態代理機制實現的框架仍是基於面嚮對象語言的擴展都不一樣程度上存在着一些不足期待着更好的語言。同時思想的實際運用也須要更好的集成開發工具支持增強代碼輔助、可視化、跟蹤調試等功能。分析設計相關理論須要不斷髮展基於的需求分析和系統設計的理論方法都很是欠缺對相關概念和思想不少在業界仍未造成共識。最後引用的話結束本文「方面仍然呆在這裏。它們仍然沒有成爲主流應用程序一部分的一個方法但它們每一天都變得更加接近」。www.docin.com北京交通大學碩士學位論文參考文獻參考文獻【】陶剛編譯‘體驗中面向方面編程》時卻年月【】著∞【】年月【】陳景燕陽國貴著下的權限控制實現》時】年月【】著技術簡介》】年月【著馮博琴等譯‘面向對象分析與設計》【】北京機械工業出版社年月【】張海潘編著‘軟件工程導論》【】北京清華大學出版社年月【】∞【】年月【】下的編寫的應用》【【‘用動態代理實現【】【著精通構建與部署應用的最佳策略》瞰】北京電子工業出版社【著潘愛民譯口哪北京機械工業出版社年月【】古全友王恩波胥昌勝技術在系統構建中的應用》【】計算機技術與發展第卷第期年月【】著個最重要的最佳實踐》【】年月【孫衛琴編著《精通對象持久化技術詳解》川電子工業出版社年月【格雷德斯基著‘精通【】清華大學出版社年月【著龔波馮軍程羣梅等譯設計模式手冊》【】機械工業出版社年月【李清華著‘基於的系統實現研究》武漢大學碩士學位論文年月【】範武蘇一‘基於編織技術的緩存框架研究和實現》【】軟件導刊年期【∞著‘www.docin.com——一韭至至望查差堡圭竺垡笙蘭堡查蘭堅》【】電子工業出版社年月】塒刪著》】
【?【】「【咖【】【美詹森美赫魯著譯∞刪㈣》中文版【電子工業出版社年月【著》【年月【著阱】年月【著》【】北京機械工業出版社年月著【北京機械工業出版社【】》】年月www.docin.com北京交通大學碩士學位論文做者簡歷做者簡歷教育經歷年月一至今就讀於北京交通大學軟件學院計算機軟件與理論專業軟件工程方向攻讀碩士學位年月一年月就讀於華中師範教育技術學專業計算機輔助教育方向獲理學學士學位工做實習經歷年月一年月實習於北京協力金橋軟件技術有限責任公司職位工程師年月一年月兼職於長城企業戰略諮詢研究所職位工程師年月年月任教於九江學院主講課程語言程序設計。主要工程項目年月一年月參與中國網通客戶關係管理》主要技術框架主要職責網管數據交換接口、用戶數據同步接口和統一審批固化模塊的設計與開發。年月一年月參與‘中學生心理健康測試系統》主要的技術框架包括的、、等功能、本人承擔的主要工做一些特殊問卷測試、數據統計分析、系統配置模塊、自定義問卷發佈等模塊的數據庫設計與開發以及一些通用代碼的編寫。本人的工做量佔整個項目三分之一以上年月年月我的承接《國家軟件專業孵化器技術支持中心北交大分中心》的設計與開發。本人主要工做數據庫設計、系統架構除論壇和美工之外幾乎全部功能模塊設計開發實現各個中心之間的註冊用戶的單點等錄部分編碼。論文發表狀況‘面向方面編程在多層架構中業務層的應用》發表於《計算機技術與發展》年第期《基於多層架構中層對數據庫訪問的優化》發表於《鐵路計算機應用》年第期www.docin.com北京交通大學碩士學位論文首創性聲明首創性聲明本人聲明所呈交的學位論文是本人在導師指導下進行的研究工做和取得的研究成果除了文中特別加以標註和致謝之處外論文中不包含其餘人已經發表或撰寫過的研究成果也不包含爲得到北京交通大學或其餘教育機構的學位或證書而使用過的材料。與我一同工做的同志對本研究所作的任何貢獻均已在論文中做了明確的說明並表示了謝意。學位論文做者簽名弋包簪罕簽字日期。一口年月仁日www.docin.com學位論文版權使用受權書本學位論文做者徹底瞭解北京交通大學有關保留、使用學位論文的規定。特受權北京交通大學能夠將學位論文的所有或部份內容編入有關數據庫進行檢索並
採用影印、縮印或掃描等複製手段保存、彙編以供查閱和借閱。贊成學校向國家有關部門或機構送交論文的複印件和磁盤。保密的學位論文在解密後適用本受權說明學位論文做者簽名眵暉簽字日期年月日新簽名嬲簽字日期仞彩年日www.docin.com 正則表達式