日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
宅男程序員給老婆的計算機課程之8:控制器

設(shè)計模式再“高級”一點,便是所謂的“框架”了。

從事Web開發(fā),一般都會接觸到MVC框架這個概念。

M:也就是Model,直接跟網(wǎng)站數(shù)據(jù)庫相關(guān)。

V:也就是View,是網(wǎng)頁的模版,跟顯示數(shù)據(jù)相關(guān)。

C:則是Controller,相當于網(wǎng)站的業(yè)務(wù)邏輯。

MVC也不僅僅是應(yīng)用于網(wǎng)站開發(fā),它的概念實際上植根于桌面軟件,并且在手機軟件開發(fā)上也有應(yīng)用。

MVC本身是一個設(shè)計模式,是一個被驗證過的,可以用來很好歸納、管理代碼的軟件開發(fā)方式。

基于這樣的設(shè)計模式,提供了很多相關(guān)的類庫實現(xiàn),則“設(shè)計模式”升級為“框架”。

MVC的任何一個方面,擴展出去講,都可以講上幾天幾夜。

今天只講C。

傳統(tǒng)上,php / asp / asp.net web form等,使用的是所謂的 Page Controller Patterns:http://martinfowler.com/eaaCatalog/pageController.html

Page Controller簡單的說,便是一個網(wǎng)址對應(yīng)一個程序文件。

所以,我們會看到大量類似: show.php / show.asp / show.aspx 的網(wǎng)址存在,這樣的網(wǎng)址,背后都有相應(yīng)同名的文件。

這樣的模式,是網(wǎng)站從靜態(tài)轉(zhuǎn)向動態(tài)是最自然的改變方便,也最為容易讓初學者接受。

但隨著網(wǎng)站的復雜化,這樣的模式會慢慢顯得不夠方便;比方說,多個不同的網(wǎng)址,映射到相同的處理;比方說,處理的時候,復用共同的資源。

頁面內(nèi)容的動態(tài)化,同一個程序文件,顯示的內(nèi)容是動態(tài)生成的 - 根據(jù)不同的query string,生成不同的內(nèi)容,如:show.php?id=1234

網(wǎng)頁程序內(nèi)部,實際上是需要解析網(wǎng)址中的query string,并做不同的操作。

這實際上是一個映射的過程,將網(wǎng)址映射到相應(yīng)的處理。

為了方便做這樣的映射,慢慢的出現(xiàn)了所謂的 Front Controller Patterns:
  http://martinfowler.com/eaaCatalog/frontController.html

這是通過某種機制,將符合各種規(guī)則的網(wǎng)址請求映射到程序中的一個類,或者是一個函數(shù)處理。

一般上,是使用正則表達式解析網(wǎng)址,并映射。

將網(wǎng)址映射到一個類;

 
 
 
  1. urls = ("/home", "hello")  
  2. app = web.application(urls, globals())  
  3.  
  4. class hello:  
  5.   def GET(self):  
  6.     return 'Hello, world!' 

將網(wǎng)址請求映射到類,是相對較“重”的處理方式,比方說,需要處理類的初始化等等。

有的框架,也可以是一個函數(shù),則相對“輕量”一些:

 
 
 
  1. (r'^$', 'home'),  
  2.  
  3. def home(request):  
  4.   return HttpResponse("Hello, world.") 

類、函數(shù),均各有優(yōu)劣,但實際差異很?。?/p>

 映射到類的方式,往往還會根據(jù)不同的HTTP header映射到類里面中相映的函數(shù),比方說,將對 /home 的HTTP GET請求映射給 hello 類的 GET 函數(shù);而對 /home 的 HTTP POST請求映射給 hello 類的POST函數(shù)。

這部分 url routing的設(shè)計與實現(xiàn),各種語言、平臺上的功能均向正則表達式靠攏,大同小異。

有的可能專門為 restful 做了優(yōu)化,但即便木有,自行實現(xiàn)也并不復雜。

很多請求,都會有一些常用的默認處理,比方說,檢查用戶是否登陸,檢查用戶是否有權(quán)限等等。

這些業(yè)務(wù)控制邏輯,是完全可以復用的。

在Page Controller的場景下,一般是通過繼承來實現(xiàn);而Front Controller場景下,而一般通過函數(shù)修飾符的風格實現(xiàn),如:

 
 
 
  1. class UploadImgHandler(BaseHandler):  
  2.  @tornado.web.authenticated  
  3.  def post(self):  
  4.   XXX 

(上述代碼,實際上既使用了繼承,也使用了修飾符。)

Controller的改進,目的在于更加方便的維護代碼、修改業(yè)務(wù)邏輯。

如果程序員有良好的開發(fā)風格,基本是使用最基礎(chǔ)的php page controller,也可以達到類似的效果。

各種“先進框架”,實際上是將常用的模式抽象出來,并通過便利的約定方式向程序員開放;如果程序員缺乏維護代碼的意識,也很可能將良好的約定習慣用濫。

需要了解的,是為什么各框架的controller設(shè)計會有這樣的設(shè)計,并用好;而不是死板的遵循“開發(fā)指南”。

在簡單業(yè)務(wù)場景下,實際上page controller會更加方便。

有這么一個“定理”:概念越簡單的模式,在處理簡單場景時,是越便利;但隨著場景復雜化,簡單的模式會越來越難以維護。

而概念相對復雜、高級的模式,處理簡單場景時,會相對麻煩;但隨著場景復雜化,則比簡單的模式容易維護。

“復雜度是守恒”的:
  模式簡單,維護則復雜。
  模式復雜,維護則簡單。

一個復雜的地方變簡單了,則另一個地方會變復雜;保持代碼結(jié)構(gòu)的清晰,不要自己給自己添麻煩。

什么叫自己給自己添麻煩?

普通復數(shù)形式,加s: pigs / cats / dogs

已經(jīng)可以很好了,但偏生有人要增加不規(guī)則復數(shù):

 sheep / mice / wives

這種就是自己給自己添麻煩。

作業(yè)

1. 說說對 restful 的理解

2. 什么是 reverse proxy ?

系列:

  1. 宅男程序員給老婆的計算機課程之0:認清本質(zhì)
  2. 宅男程序員給老婆的計算機課程之1:認清實際
  3. 宅男程序員給老婆的計算機課程之2:怎么看待牛人
  4. 宅男程序員給老婆的計算機課程之3:架構(gòu)比較
  5. 宅男程序員給老婆的計算機課程之4:SQL vs NoSQL
  6. 宅男程序員給老婆的計算機課程之5:設(shè)計模式
  7. 宅男程序員給老婆的計算機課程之6:模版引擎
  8. 宅男程序員給老婆的計算機課程之7:運維的重要性
  9. 宅男程序員給老婆的計算機課程之8:控制器

分享文章:宅男程序員給老婆的計算機課程之8:控制器
文章URL:http://m.5511xx.com/article/dpooggo.html