話說年前有個師妹淚眼汪汪,楚楚動情地找我幫她弄個企業網站。前端
不過那時候,天天都苦B地閃着:「加班中,相信不用多久升職加薪,當上總經理,出任CEO,迎娶白富美,走上人生巔峯,想一想還有點小激動呢」。sql
因此每夜都懶懶地累到不想動,一直拖延到年後,回到廣州才動有了寫代碼的衝動。數據庫
想一想畢竟是自家師妹,承諾過的仍是要還的,因此打算認真負責的花些時間把它整出來。緩存
首先這是一個義務型的網站,因此會考慮時間不能佔用太多, 儘可能知足基礎功能,比較異想天開的功能先忽略。安全
總體先後溝通和小調整,歷長1-2周,實際編碼時間,大概24小時內,換算起時間,那也是三個工做日,六個夜晚啊。服務器
A:時間不能佔用過多,開發週期不能拉長。架構
B:我的能臨時提供的服務器是2003,只有.NET 2.0,後期可能會轉移到對方購買的虛擬主機,因此部署要方便。併發
C:友好的URL並非對方在意的。 編輯器
因此綜合考慮:WebForm。分佈式
像MVC,它的優勢是:提供簡單友好的URL,對外是一個好的唬頭,MVC架構分層思想對新手是一種引導。
用MSSQL,在這種簡單的企業站裏,大財小用了。
Access:擁有最弱的併發限制,64K,這個在我之前QBlog系列文章裏,把它優化上天了,後來仍是離開了。
Sqlite:這個須要最高的信任權限,某些虛擬主機商可能會不支持,並且併發能力和Access差很少一個級別。
以我多年的實戰經歷,這裏我選擇文本數據庫,這裏有幾個重要思考因素。
1:數據量少:少到能夠預估的時間內,文章不會超過1千。
2:佔用資源少:目前VPS就1G內存,數據庫勉強跑上了sql2000,並且服務器上跑了好幾個項目,不適合把這外部的數據放置到本身的項目中。
3:性能要高,抗併發要強:服務器自己配置很低,若是不能抗併發,隨便用我提供的分佈式壓力測試就能搞掉的話,那不坑我本身的服務器。
4:數據的安全性隱私木有要求:這些數據都是可公開的。
綜合上面的考慮,MSSQL,雖然能抗併發,這個吃內存,不行,而Access和Sqlite不抗併發,若是選擇了它們,意味着我必須考慮到整個緩存機制或生成靜態頁面機制,這無疑會加長個人開發時間。
好在我發現了文本數據庫:恰好知足以上的條件,並且文本數據庫一直在應用,基本上這個企業站也不在話下,因此最後是用上了CodeFirst方式的文本數據庫。
而選擇文本數據庫,經壓力測試,幾千上萬個併發也不是問題,它自然的內存數據庫機制自己就是緩存機制,一次開發,就能夠收工了。
首先,她不是美工,我也不會美工,因此,網站須要有參考,好在她給了一款參考網站。
因此,以個人經驗,把對方網站那點皮膚弄下來不是什麼問題,因此美工的問題看似就解決了,具體看一眼下圖,發現是很清秀簡潔的:
因爲數據庫選項是文本數據庫,因此基本上就是CodeFirst,定義好業務實體,什麼分層,在這裏就是浮雲:
Web.Config就這麼一行了:
具體運行後產生的數據存儲,就在App_Data下的db文件夾下了,一個表就對應一個文本數據了。
另外考慮到文章的字節大,就單獨隔離出來一個body文件夾來存放文章,代碼也很簡單:
紅色那一塊是後臺,因爲偷工減料,因此就不方便公開名稱。
整個網站,基本上都是簡單相似如下的代碼:
不過也有一些須要費點腦的:
面對這個問題,有着最開始的設計思惟:
A:分類名稱難道是文章的名稱(由於見過的不少基本上都是同名) ?
B:那麼要區分顯示在列表仍是單獨的,要在文章里加個字段以區別?
中間的過渡思惟:
A:分類名稱就是分類名稱?
B:分類名稱上加個字段,以區別點擊是進入指定的某個文章?
最後的決定性思惟:
A:分類名稱仍是分類名稱。
B:當分類名稱只有一條文章時,地址變爲直接指向那篇文章。
一開始我是很偷懶的,用一個文本框來發文章,就想了理了。
後來想一想不能懶到這程度,畢竟人家是師妹啊,況且我還單身,因此引入文本編輯器升級一下檔次也是有必要的。
網上可選的編輯種類不少,FCK,King等網上一搜一個堆,不過我仍是思考了一下,若是用上這些:
第一,重,隨便一個都幾M起步;
第二,圖片上傳須要本身再折騰,若是運氣很差,研究+實現可能會花上一天時間。
第三:我太懶了,我想最多1小時之內就把它給換完。
我想到之前QBlog裏我寫過一個編輯器(改來的),因而直接弄過來,發現原來的代碼和QBlog的開發模式有點結合。
花了幾分鐘,改了點代碼,基本上就能用了,並且重點是文件上傳,基本上小改幾分鐘也適合着用了,省了很多時間。
這一塊就沒什麼好說的了,就是那種一點圖片出來一遮照層,整個背景黑的那種,06年就開始流行的,沒想到如今還用的上。
對於後臺,一開始打算用QBlog那種後臺方式,或者像EasyUI那種前端,而後搞個CodeSmith批量生成同樣,不過一想到這CS不知道放哪了,光找出來就要很多時間,再說它也不支持個人文本數據庫。
雖然CodeFirst也支持多種數據庫,改個數據庫連接就能夠轉移到其它數據庫,而後再借CS去生成,不過感受這轉來轉去的麻煩。
因而,心一橫,就那幾個表,也就幾個界面,還不如手工來的快,因而一個木有樣式,慘不忍睹的界面,只有最簡單的增刪改查邏輯的後臺就出來了。
因爲後臺界面這一塊太醜,就不截圖了,免的亮瞎了大夥的眼睛。
網站預覽(已失效):http://paileju.com
至於源碼,想要來學習的也能夠Q我,隨便給。
到此,基本上就算完工了,搞完以後,收到了師妹寄來的零食,也算是一種回報了,雖然大部分零售是辣的不合我口味,不過仍是有很多零售味道仍是不錯的,像那個1塊錢1個的肉鬆餅就很好吃,但是,爲啥只買了一個,納尼?