欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

零基礎(chǔ)之Node.js搭建API服務(wù)器的詳解

 更新時(shí)間:2019年03月08日 11:35:50   作者:沙沙羅曼  
今天小編就為大家分享一篇關(guān)于零基礎(chǔ)之Node.js搭建API服務(wù)器的詳解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧

零基礎(chǔ)之Node.js搭建API服務(wù)器

這篇文章寫給那些Node.js零基礎(chǔ),但希望自己動(dòng)手實(shí)現(xiàn)服務(wù)器API的前端開發(fā)者,嘗試幫大家打開一扇門。

HTTP服務(wù)器實(shí)現(xiàn)原理

HTTP服務(wù)器之所以能提供前端使用的API,其實(shí)現(xiàn)原理是服務(wù)器保持監(jiān)聽計(jì)算機(jī)的某個(gè)端口(通常是80),等待客戶端請求,當(dāng)請求到達(dá)并經(jīng)過一系列處理后,服務(wù)器發(fā)送響應(yīng)數(shù)據(jù)給到前端。

平時(shí)大家通過Ajax調(diào)用API,即是發(fā)起一次請求,經(jīng)過服務(wù)器處理后,得到結(jié)果,然后再進(jìn)行前端處理。如今使用高級(jí)編程語言,要實(shí)現(xiàn)服務(wù)器那部分功能已經(jīng)變得非常簡單,接下來我們了解一下使用Node.js如何實(shí)現(xiàn)。

什么是Node.js?它可以做什么?

Node.js是一個(gè)JavaScript的運(yùn)行時(shí)(runtime),它提供了大量用JS與操作系統(tǒng)打交道的API,通過這些API,我們可以調(diào)用本地程序、讀寫磁盤、監(jiān)聽端口、發(fā)起網(wǎng)絡(luò)請求等,這足以開發(fā)出一個(gè)功能完善的Server。

前期準(zhǔn)備

簡單介紹完Node.js,開始寫代碼之前,我們需要安裝Node.js,安裝詳細(xì)過程就不說明了,請大家Google或者百度。不同系統(tǒng)安裝過程不一樣,如果是Linux、Mac,會(huì)相對(duì)順利且遇到問題的可能性較低。

判斷安裝成功與否,windows下,在cmd中執(zhí)行node -v,Linux、Mac下,在shell中執(zhí)行node -v,正常輸出版本號(hào)說明安裝成功。

tips:

windows如果提示命令未找到,可能是未配置環(huán)境變量

實(shí)現(xiàn)簡單的Server

Node.js安裝成功,我們找個(gè)地方新建目錄my-server作為我們的存放代碼的地方,接下來所有的代碼都在該目錄下。首先,在my-server的目錄下新建文件index.js,用如下代碼實(shí)現(xiàn)一個(gè)簡單的Server:

// index.js
// 通過require獲取兩個(gè)node內(nèi)置模塊
const http = require('http');
const nUrl = require('url');
// '127.0.0.1'表明只有本機(jī)可訪問,'0.0.0.0'表示所有人可訪問
const hostname = '127.0.0.1';
const port = 3000;
// 通過http.createServer獲取一個(gè)server實(shí)例
// 其中(req, res) => {},在服務(wù)器每次接收到請求時(shí)都會(huì)被執(zhí)行
const server = http.createServer((req, res) => {
  let method = req.method; // 客戶端請求方法
  let url = nUrl.parse(req.url); // 將請求url字符串轉(zhuǎn)換為node的url對(duì)象
  // 如果客戶端GET請求'/',會(huì)執(zhí)行這個(gè)分支里面的邏輯
  if (method === 'GET' && url.pathname === '/') {
    res.statusCode = 200;
    res.setHeader('Content-Type', 'text/plain');
    res.end('Hello World');
    return;
  }
  // 如果客戶端GET請求'/api/user',會(huì)執(zhí)行這個(gè)分支里面的邏輯
  if (method === 'GET' && url.pathname === '/api/user') {
    res.statusCode = 200;
    res.setHeader('Content-Type', 'application/json');
    res.end(JSON.stringify({
      code: 0,
      msg: '',
      result: {
        username: 'shasharoman'
      }
    }));
    return;
  }
  // 沒有匹配其他分支的話,執(zhí)行以下邏輯
  res.statusCode = 404;
  res.setHeader('Content-Type', 'text/plain');
  res.end('Not Found');
});
// server開始監(jiān)聽,等待請求到來
server.listen(port, hostname, () => {
  console.log(`Server running at http://${hostname}:${port}/`);
});

文件內(nèi)容編輯保存后,在my-server目錄下通過命令node index.js啟動(dòng)服務(wù),然后在瀏覽器中訪問http://127.0.0.1:300/、http://127.0.0.1:300/api/user、http://127.0.0.1:300/xxx觀察不同結(jié)果。

這是官方Guides經(jīng)過小小修改得到的代碼,添加部分注釋以及額外邏輯。主要為了更清晰傳達(dá)以下幾個(gè)知識(shí)點(diǎn):

  • 從req對(duì)象上獲取method與url,這個(gè)req對(duì)象是客戶端請求的“抽象表現(xiàn)”,平時(shí)寫Ajax指定的絕大部分內(nèi)容都可以從該對(duì)象上獲取
  • 中間添加的兩個(gè)if分支,主要是為了讓大家了解服務(wù)器如何區(qū)分不同請求,決定做不同事情,即路由概念
  • Content-Type: application/json,通常API會(huì)使用的響應(yīng)格式,表明返回?cái)?shù)據(jù)是json格式,這是一個(gè)HTTP頭部,屬于HTTP協(xié)議相關(guān)知識(shí)
  • statusCode:404,HTTP最常見的錯(cuò)誤“Not Found”,也屬于HTTP協(xié)議相關(guān)知識(shí)

往前優(yōu)化一步

通過上面的代碼,實(shí)現(xiàn)了一個(gè)簡單Server,但真實(shí)場景下我們會(huì)這樣去實(shí)現(xiàn)嗎?答案是肯定不會(huì),所以我們還需要一步步完善,做以下幾個(gè)修改:

  • 增加config,在其中配置hostname,port
  • 增加controller,用于分層以及分模塊
  • 增加route,用于定義路由

代碼不多,一共五個(gè)文件:

  • config.js,配置文件
  • route.js,路由定義文件
  • controller/account.js,賬號(hào)模塊業(yè)務(wù)實(shí)現(xiàn)文件
  • controller/index.js,業(yè)務(wù)匯總并暴露給外部
  • index.js,項(xiàng)目啟動(dòng)文件
// config.js
exports = module.exports = {
  hostname: '127.0.0.1',
  port: '3000'
};
// route.js
exports = module.exports = [{
  method: 'GET',
  path: '/api/user',
  impl: 'account.userById'
}, {
  method: 'POST',
  path: '/api/user',
  impl: 'account.createUser'
}];
// controller/account.js
exports.userById = userById;
exports.createUser = createUser;
function userById(req, res) {
  res.end('waiting for impl.');
}
function createUser(req, res) {
  res.end('waiting for impl.');
}
// controller/index.js
exports.account = require('./account');
// index.js
const http = require('http');
const nUrl = require('url');
const config = require('./config');
const controller = require('./controller');
const route = require('./route').map(item => {
  console.log(`route ${item.method}:${item.path}`);
  let tuple = item.impl.split('.');
  item.impl = controller[tuple[0]][tuple[1]];
  return item;
});
const server = http.createServer((req, res) => {
  let method = req.method;
  let url = nUrl.parse(req.url);
  let matchRoute = route.find(item => {
    return item.method === method && item.path === url.pathname;
  });
  if (matchRoute) {
    matchRoute.impl(req, res);
    return;
  }
  res.statusCode = 404;
  res.setHeader('Content-Type', 'text/plain');
  res.end('Not Found');
});
server.listen(config.port, config.hostname, () => {
  console.log(`Server running at http://${config.hostname}:${config.port}/`);
});

依舊是用node index.js啟動(dòng)Server,如果要在現(xiàn)有模式下開發(fā)一個(gè)API,主要就兩步:

  • 在route.js中定義路由
  • 在controller/中實(shí)現(xiàn)

做這個(gè)程度的優(yōu)化,只是為了向大家傳達(dá)一些比較寬泛的概念,還不是真正用來寫API服務(wù),只是為了大伙練練手。

這個(gè)程度還達(dá)不到真實(shí)場景需求,還需要經(jīng)過幾輪改造,包括模塊、層、common、lib、query解析,body解析、更靈活的route等一系列事情,限于篇幅,有機(jī)會(huì)在一一講述。

經(jīng)過我的描述以及代碼示例,如果大家有興趣學(xué)習(xí)Node.js,建議多搜搜相關(guān)知識(shí),保持關(guān)注,然后在逐步去熟悉Node.js流行的Web框架如:Express、Koa等,不過框架只是更高層面的封裝,基礎(chǔ)的概念以及知識(shí)還是需要花時(shí)間才能掌握。

如果前端想嘗試后端編程,請一定先學(xué)習(xí)HTTP協(xié)議,推薦《HTTP權(quán)威指南》從頭到尾認(rèn)真看一遍。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • node?+?multer?實(shí)現(xiàn)文件上傳過程

    node?+?multer?實(shí)現(xiàn)文件上傳過程

    這篇文章主要介紹了node?+?multer?實(shí)現(xiàn)文件上傳過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Electron 調(diào)用命令行(cmd)

    Electron 調(diào)用命令行(cmd)

    這篇文章主要介紹了Electron 調(diào)用命令行(cmd),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Node.js中Process.nextTick()和Process.setImmediate()的區(qū)別

    Node.js中Process.nextTick()和Process.setImmediate()的區(qū)別

    這篇文章介紹了Node.js中Process.nextTick()和Process.setImmediate()的區(qū)別,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • 史上無敵詳細(xì)的Node.Js環(huán)境搭建步驟記錄

    史上無敵詳細(xì)的Node.Js環(huán)境搭建步驟記錄

    Node.js是一個(gè)事件驅(qū)動(dòng)I/O服務(wù)端JavaScript環(huán)境,由于其擁有異步非阻塞、環(huán)境搭建簡單、實(shí)踐應(yīng)用快等特性,使得其在新一代編程開發(fā)中更為流行,下面這篇文章主要給大家介紹了關(guān)于Node.Js環(huán)境搭建步驟記錄的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • Node.js連接postgreSQL并進(jìn)行數(shù)據(jù)操作

    Node.js連接postgreSQL并進(jìn)行數(shù)據(jù)操作

    自從MySQL被Oracle收購以后,PostgreSQL逐漸成為開源關(guān)系型數(shù)據(jù)庫的首選。這篇文章就給大家介紹了關(guān)于Node.js如何連接postgreSQL數(shù)據(jù)庫,并進(jìn)行數(shù)據(jù)操作的方法,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • NodeJs模擬登陸正方教務(wù)

    NodeJs模擬登陸正方教務(wù)

    網(wǎng)上已經(jīng)有很多關(guān)于模擬登陸正方教務(wù)的作品了,基于 PHP,Python,Java,.Net 加上NodeJs,這幾門語言都可以實(shí)現(xiàn)模擬登陸,模擬登陸的技術(shù)點(diǎn)不是特別難,這里記錄一下利用Node碰到的一些坑,以及一些解決思路。
    2017-04-04
  • 3分鐘快速搭建nodejs本地服務(wù)器方法運(yùn)行測試html/js

    3分鐘快速搭建nodejs本地服務(wù)器方法運(yùn)行測試html/js

    本篇文章主要介紹了3分鐘快速搭建nodejs本地服務(wù)器方法運(yùn)行測試html/js,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-04-04
  • 淺談Node異步編程的機(jī)制

    淺談Node異步編程的機(jī)制

    本篇文章主要介紹了淺談Node異步編程的機(jī)制,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • Node.js使用bcrypt-pbkdf實(shí)現(xiàn)密碼加密

    Node.js使用bcrypt-pbkdf實(shí)現(xiàn)密碼加密

    在這個(gè)數(shù)字時(shí)代,保護(hù)用戶密碼的重要性不言而喻,作為一名資深的前端開發(fā)工程師和技術(shù)博客作者,今天我將帶你詳細(xì)了解如何在 Node.js 環(huán)境中利用 bcrypt-pbkdf 模塊進(jìn)行密碼的哈希處理,確保你的應(yīng)用安全性得到有效提升,需要的朋友可以參考下
    2024-05-05
  • Nodejs極簡入門教程(一):模塊機(jī)制

    Nodejs極簡入門教程(一):模塊機(jī)制

    這篇文章主要介紹了Nodejs極簡入門教程(一):模塊機(jī)制,本文講解了模塊基礎(chǔ)知識(shí)、模塊的加載、包等內(nèi)容,需要的朋友可以參考下
    2014-10-10

最新評(píng)論