使用LeanCloud+NodeJS+Express 搭建App的服務(wù)端

本文將介紹
1棍鳖、如何快速地搭建一個(gè)簡單的服務(wù)端渣叛,提供App和web可以訪問的接口
2粘秆、如何將服務(wù)器部署到LeanCloud上

一粹胯、創(chuàng)建項(xiàng)目

首先你需要安裝NodeJS環(huán)境 這里不再做介紹

1.安裝Express

  sudo npm install express -g
  sudo npm install express-generator -g

2.初始化項(xiàng)目

  cd /Users/SPRINT/Desktop 進(jìn)入桌面
  express 項(xiàng)目名稱
EA6F31DE-C6DA-4494-96F3-CD5D5C52C85A.png
  cd 項(xiàng)目名稱
  npm install

回到桌面 將看到一個(gè)wuappserver目錄 這里使用Sublime Text打開

59FE6358-4C4B-4265-9FB3-385970D95F02.png

/bin:用來啟動(dòng)應(yīng)用(服務(wù)器)
/public: 存放靜態(tài)資源目錄
/routes:路由用于確定應(yīng)用程序如何響應(yīng)對(duì)特定端點(diǎn)的客戶機(jī)請(qǐng)求特幔,包含一個(gè) URI(或路徑)和一個(gè)特定的 HTTP 請(qǐng)求方法(GET咨演、POST 等)。每個(gè)路由可以具有一個(gè)或多個(gè)處理程序函數(shù)蚯斯,這些函數(shù)在路由匹配時(shí)執(zhí)行薄风。
/views: 模板文件所在目錄 文件格式為.jade
目錄app.js程序main文件 這個(gè)是服務(wù)器啟動(dòng)的入口

二、啟動(dòng)本地服務(wù)

npm start   //啟動(dòng)服務(wù)器

啟動(dòng)完成后終端將輸出 node ./bin/www
在瀏覽器中訪問 http://localhost:3000/

三拍嵌、定義接口

如果我們想要實(shí)現(xiàn)一個(gè)獲取用戶信息接口該怎么寫呢遭赂?
很簡單在 routes目錄下創(chuàng)建一個(gè)user.js文件內(nèi)容如下:

E911CFF2-DE66-42C3-AFEC-3D4B9F513DB8.png

定義一個(gè)User模型

function User() {
      this.name;
      this.city;
      this.age;
}
module.exports = User;

切換到users.js文件
在文件頂部添加

 var URL = require('url');
var User = require('./user');

并繼續(xù)添加如下內(nèi)容:

// 返回對(duì)象
router.get('/getUserInfo', function(req, res, next) {

    var user = new User();
    var params = URL.parse(req.url, true).query;

 if(params.id == '1') {

    user.name = "羅子君";
    user.age = "37";
    user.city = "上海市";

}else{    
    user.name = "賀函";
    user.age = "36";
    user.city = "上海市";
}

  var response = {status:1,data:user};
  res.send(JSON.stringify(response));

});

// 返回簡單的 JSON
router.get('/getAll', function(req, res, next) {

  var data = {
    "靳東":"賀涵", "馬伊琍":"羅子君", "袁泉":"唐晶", "雷佳音":"陳俊生 ", "吳越":"凌玲", "許娣":"薛甄珠", "張齡心":"羅子群", "鄔君梅":"吳大娘", "欒元暉":"白光", "鄭羅茜":"薇薇安", "啜妮":"洛洛", "梅婷":"卓漸清前女友", "譚凱":"Adom", "孔維":"單身女人", "張棪琰":"蘇曼殊", "侯巖松":"老金", "魏之皓":"平兒", "王天澤":"冷佳清", "于明加":"安琪兒CEO", "任東霖":"李睿", "張衣":"羅平", "黃瀾":"M女士", "陳道明":"卓漸清"
  }

  var response = {status:1,data:data};
  res.send(JSON.stringify(response));

});

停止服務(wù)器 重新start服務(wù)器即可直接訪問
調(diào)用方式
http://localhost:3000/users/getUserInfo?id=1
或者
http://localhost:3000/users/getUserInfo?id=2

DD4C826C-9397-429B-A16B-1D54383247CC.png

四、部署到LeanCloud

1横辆、LeanCloud 對(duì)于每個(gè)應(yīng)用都默認(rèn)贈(zèng)送一個(gè)「基本資源 0.5 CPU + 256 MB 內(nèi)存」的體驗(yàn)實(shí)例撇他,可以免費(fèi)使用,供開發(fā)者學(xué)習(xí)和測試云引擎龄糊,因此我們選擇LeanCloud逆粹。
2、LeanCloud部署是需要設(shè)置代碼庫炫惩,因此我們需要先把剛才創(chuàng)建的項(xiàng)目提交到Git倉庫僻弹,我們選擇 github倉庫

1、GitHub 新建倉庫

9881206E-C206-47F6-B25B-76E63F0143F3.png

創(chuàng)建成功

4E992E29-B474-4265-87C0-B88C759BAAB9.png

復(fù)制倉庫地址他嚷,在終端執(zhí)行下面命令蹋绽,將代碼clone到本地

cd desktop
git clone 倉庫地址

桌面上會(huì)多一個(gè)名為 webserver 的文件夾芭毙,將第一步創(chuàng)建項(xiàng)目文件夾下的所有文件復(fù)制到 webserver 文件夾下,執(zhí)行以下命令提交到倉庫

git add .
git commit -m'info'
git push

這時(shí)再回到GitHub卸耘,會(huì)發(fā)現(xiàn)剛才新建的倉庫里面已經(jīng)有我們創(chuàng)建的項(xiàng)目了


3918218C-181E-4DE5-9153-84F2BDA2AFE6.png

2退敦、設(shè)置LeanCloud

  • 注冊(cè)LeanCloud,新建一個(gè)應(yīng)用
  • 設(shè)置
    設(shè)置git倉庫地址
61EBF32F-A70E-4C86-A337-4F44E3376AF7.png

設(shè)置主機(jī)域名

97FAE0FF-C0F3-4D8F-B72E-0E27A19F4617.png
  • 部署服務(wù)
E8EC026A-7967-4D16-9ED1-C77AE8F60E68.png

部署成功后蚣抗,將看到實(shí)例狀態(tài) “運(yùn)行中”侈百,至此,服務(wù)器已經(jīng)啟動(dòng)翰铡,服務(wù)器的地址钝域,就是上一步設(shè)置的主機(jī)域名!

FDBE8641-4277-4730-B506-3582A59AB20C.png

五锭魔、測試接口

利用Postman模擬App發(fā)送Get請(qǐng)求

EB723FD0-3204-4A4D-9893-5C7C91BE1FB9.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末例证,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子迷捧,更是在濱河造成了極大的恐慌织咧,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件漠秋,死亡現(xiàn)場離奇詭異笙蒙,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)庆锦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門手趣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人肥荔,你說我怎么就攤上這事绿渣。” “怎么了燕耿?”我有些...
    開封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵中符,是天一觀的道長。 經(jīng)常有香客問我誉帅,道長淀散,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任蚜锨,我火速辦了婚禮档插,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘亚再。我一直安慰自己郭膛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開白布氛悬。 她就那樣靜靜地躺著则剃,像睡著了一般耘柱。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上棍现,一...
    開封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天调煎,我揣著相機(jī)與錄音,去河邊找鬼己肮。 笑死士袄,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的谎僻。 我是一名探鬼主播窖剑,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼戈稿!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起讶舰,我...
    開封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤鞍盗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后跳昼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體般甲,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年鹅颊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了敷存。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡堪伍,死狀恐怖锚烦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情帝雇,我是刑警寧澤涮俄,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站尸闸,受9級(jí)特大地震影響彻亲,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吮廉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一苞尝、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧宦芦,春花似錦宙址、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽豁辉。三九已至,卻和暖如春舀患,著一層夾襖步出監(jiān)牢的瞬間徽级,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國打工聊浅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留餐抢,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓低匙,卻偏偏與公主長得像旷痕,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子顽冶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理欺抗,服務(wù)發(fā)現(xiàn),斷路器强重,智...
    卡卡羅2017閱讀 134,599評(píng)論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,748評(píng)論 6 342
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,506評(píng)論 25 707
  • 失去希望 《人鼠之間》(Of Mice andMen)約翰?斯坦貝克(John Steinbeck) 永遠(yuǎn)別低估希...
    蘿卜閱讀 106評(píng)論 0 0
  • 短短四五年绞呈,云的時(shí)代已經(jīng)不可阻擋,并逐步吞噬和改變了原來的IT基礎(chǔ)架構(gòu)间景,形成了一套完整的云基礎(chǔ)架構(gòu)服務(wù)佃声。但是否向云...
    楊文飛閱讀 332評(píng)論 0 0