勺子開發(fā)架構(gòu)分享02 -- NodeJS+Express+MongoDB

Node.js && Express

Node.js 是一個(gè)基于Chrome JavaScript運(yùn)行時(shí)建立的一個(gè)平臺(tái)酱床,用來(lái)方便地搭建快速的易于擴(kuò)展的網(wǎng)絡(luò)應(yīng)用羊赵。
Node.js 借助事件驅(qū)動(dòng),非阻塞I/O 模型變得輕量和高效扇谣,非常適合運(yùn)行在分布式設(shè)備的數(shù)據(jù)密集型的實(shí)時(shí)應(yīng)用昧捷。
V8引擎執(zhí)行Javascript的速度非常快罐寨,性能非常好靡挥。Node對(duì)一些特殊用例進(jìn)行了優(yōu)化,提供了替代的API鸯绿,使得V8在非瀏覽器環(huán)境下運(yùn)行得更好跋破。(摘自百度百科)

Express是NodeJS的一個(gè)框架。能夠幫助人們快速建立起一個(gè)NodeJS網(wǎng)站瓶蝴。

關(guān)于nodejs和express的學(xué)習(xí)資料可以去CNode查找毒返。

MongoDB

MongoDB是一個(gè)開源的NonSQL數(shù)據(jù)庫(kù)。最主要的特點(diǎn)是Document-Orientanted Storage舷手。即JSON-style documents with dynamic schemas offer simplicity and power.
MongoDB的數(shù)據(jù)庫(kù)設(shè)計(jì)有一個(gè)理念是不要按照Model的邏輯來(lái)設(shè)計(jì)數(shù)據(jù)庫(kù)拧簸,而是按照應(yīng)用場(chǎng)景。
例如聚霜,現(xiàn)在有一個(gè)博客狡恬。數(shù)據(jù)庫(kù)里面有一個(gè)叫Post的文檔(表)珠叔,代表一篇博客。每一篇博客有若干個(gè)評(píng)論(comment)弟劲。那么設(shè)計(jì)的時(shí)候有兩種方式可選:

  1. Post內(nèi)部有一個(gè)數(shù)組祷安,記錄了所有comment這個(gè)子文檔(sub-document)。結(jié)構(gòu)如下:
    Post

    {
      title: "文章標(biāo)題",
      content: "文章內(nèi)容",
      comments: [
            {user:"發(fā)布的用戶ID", content:"評(píng)論內(nèi)容1"},
            {user:"發(fā)布的用戶ID", content:"評(píng)論內(nèi)容2"}
      ]
    }
    
  2. Post和Comment相分離兔乞。結(jié)構(gòu)如下:
    Post

    {
      title: "文章標(biāo)題",
      content: "文章內(nèi)容",
      comments: [commentID1, commentID2]
    }
    

Comment

   {
     _id: "ObjectId(xxxxxxxxxxxxxx)"
     user:"發(fā)布的用戶ID", 
     content:"評(píng)論內(nèi)容"
   }

在MongoDB中汇鞭,兩種設(shè)計(jì)并無(wú)優(yōu)劣之分,應(yīng)該選用哪種設(shè)計(jì)取決于產(chǎn)品的應(yīng)用場(chǎng)景庸追。即:一個(gè)帖子下面的評(píng)論霍骄,是不是只會(huì)顯示在和帖子一個(gè)頁(yè)面?如果是的話淡溯,就選擇第一種設(shè)計(jì)方式读整。
比如有一個(gè)網(wǎng)站,會(huì)把精彩評(píng)論放到首頁(yè)去咱娶。每個(gè)評(píng)論和帖子有關(guān)聯(lián)但相對(duì)獨(dú)立米间。這樣的話,第二種設(shè)計(jì)方式就比較好膘侮。
勺子的收藏分享中的評(píng)論以及點(diǎn)贊屈糊,是按照第一種設(shè)計(jì)方式來(lái)的。

IDE

勺子項(xiàng)目使用了WebStorm作為IDE琼了。在WebStore的新建項(xiàng)目的模板中逻锐,可以直接選擇express項(xiàng)目模板。這樣一個(gè)基本的nodejs+express的項(xiàng)目就建立好了雕薪。

登錄注冊(cè)系統(tǒng)

基于Token的驗(yàn)證

勺子舍棄了傳統(tǒng)的session方式昧诱,采用了基于Token的驗(yàn)證方式。其優(yōu)點(diǎn)以及實(shí)現(xiàn)方式見(jiàn)Cookies vs Tokens. Getting auth right with Angular.JS

路由設(shè)計(jì)

由于網(wǎng)站前端將會(huì)用AngularJS來(lái)設(shè)計(jì)所袁,所以網(wǎng)站的路由其實(shí)就是API部分鳄哭。所以對(duì)于網(wǎng)站的路由請(qǐng)求,分為兩部分:

  1. 所有以/api為開頭的請(qǐng)求纲熏,交給API部分來(lái)處理妆丘。
  2. 所有其他請(qǐng)求,服務(wù)器都把AngularJS的app發(fā)送給瀏覽器局劲。由AngularJS來(lái)管理路由勺拣。

API設(shè)計(jì)

API分為以下幾大模塊:

  • Auth模塊:負(fù)責(zé)處理注冊(cè)、登錄鱼填。
  • 收藏模塊:負(fù)責(zé)收藏這個(gè)Resource的CRUD事件药有。Comment事件。點(diǎn)贊事件,搜索等愤惰。
  • 用戶模塊:負(fù)責(zé)用戶的修改資料苇经,用戶的資料顯示,關(guān)注/取消關(guān)注等事件宦言。
  • 收藏夾模塊:負(fù)責(zé)收藏夾的CRUD扇单。關(guān)注/取消關(guān)注單個(gè)收藏夾。
  • 消息模塊:負(fù)責(zé)記錄和處理評(píng)論消息奠旺、點(diǎn)贊消息蜘澜、私信。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末响疚,一起剝皮案震驚了整個(gè)濱河市鄙信,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌忿晕,老刑警劉巖装诡,帶你破解...
    沈念sama閱讀 216,470評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異践盼,居然都是意外死亡慎王,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門宏侍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蜀漆,你說(shuō)我怎么就攤上這事谅河。” “怎么了确丢?”我有些...
    開封第一講書人閱讀 162,577評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵绷耍,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我鲜侥,道長(zhǎng)褂始,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,176評(píng)論 1 292
  • 正文 為了忘掉前任描函,我火速辦了婚禮崎苗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘舀寓。我一直安慰自己胆数,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評(píng)論 6 388
  • 文/花漫 我一把揭開白布互墓。 她就那樣靜靜地躺著必尼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上判莉,一...
    開封第一講書人閱讀 51,155評(píng)論 1 299
  • 那天豆挽,我揣著相機(jī)與錄音,去河邊找鬼券盅。 笑死帮哈,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的渗饮。 我是一名探鬼主播但汞,決...
    沈念sama閱讀 40,041評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼互站!你這毒婦竟也來(lái)了私蕾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,903評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤胡桃,失蹤者是張志新(化名)和其女友劉穎踩叭,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體翠胰,經(jīng)...
    沈念sama閱讀 45,319評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡容贝,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了之景。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片斤富。...
    茶點(diǎn)故事閱讀 39,703評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖锻狗,靈堂內(nèi)的尸體忽然破棺而出满力,到底是詐尸還是另有隱情,我是刑警寧澤轻纪,帶...
    沈念sama閱讀 35,417評(píng)論 5 343
  • 正文 年R本政府宣布油额,位于F島的核電站,受9級(jí)特大地震影響刻帚,放射性物質(zhì)發(fā)生泄漏潦嘶。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評(píng)論 3 325
  • 文/蒙蒙 一崇众、第九天 我趴在偏房一處隱蔽的房頂上張望掂僵。 院中可真熱鬧,春花似錦顷歌、人聲如沸看峻。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)互妓。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間冯勉,已是汗流浹背澈蚌。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留灼狰,地道東北人宛瞄。 一個(gè)月前我還...
    沈念sama閱讀 47,711評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像交胚,于是被迫代替她去往敵國(guó)和親份汗。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容