溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Node.js中怎么使用原生API實現(xiàn)一個Web服務器

發(fā)布時間:2021-07-21 09:36:10 來源:億速云 閱讀:175 作者:Leah 欄目:web開發(fā)

這期內容當中小編將會給大家?guī)碛嘘PNode.js中怎么使用原生API實現(xiàn)一個Web服務器,文章內容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

Hello World

要搭建一個簡單的Web服務器,使用原生的http模塊就夠了,一個簡單的Hello World程序幾行代碼就夠了:

const http = require('http')  const port = 3000  const server = http.createServer((req, res) => {    res.statusCode = 200    res.setHeader('Content-Type', 'text/plain')    res.end('Hello World')  })  server.listen(port, () => {    console.log(`Server is running on http://127.0.0.1:${port}/`)  })

這個例子就很簡單,直接用http.createServer創(chuàng)建了一個服務器,這個服務器也沒啥邏輯,只是在訪問的時候返回Hello World。服務器創(chuàng)建后,使用server.listen運行在3000端口就行。

這個例子確實簡單,但是他貌似除了輸出一個Hello World之外,啥也干不了,離我們一般使用的Web服務器還差了很遠,主要是差了這幾塊:

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術社區(qū)

  2.  不支持HTTP動詞,比如GET,POST等

  3.  不支持路由

  4.  沒有靜態(tài)資源托管

  5.  不能持久化數據

前面三點是一個Web服務器必備的基礎功能,第四點是否需要要看情況,畢竟目前很多Node的Web服務器只是作為一個中間層,真正跟數據庫打交道做持久化的還是各種微服務,但是我們也應該知道持久化怎么做。

所以下面我們來寫一個真正能用的Web服務器,也就是說把前面缺的幾點都補上。

處理路由和HTTP動詞

前面我們的那個Hello World也不是完全不能用,因為代碼位置還是得在http.createServer里面,我們就在里面添加路由的功能。為了跟后面的靜態(tài)資源做區(qū)分,我們的API請求都以/api開頭。要做路由匹配也不難,最簡單的就是直接用if條件判斷就行。為了能拿到請求地址,我們需要使用url模塊來解析傳過來的地址。而Http動詞直接可以用req.method拿到。所以http.createServer改造如下:

const url = require('url');  const server = http.createServer((req, res) => {    // 獲取url的各個部分    // url.parse可以將req.url解析成一個對象    // 里面包含有pathname和querystring等    const urlurlObject = url.parse(req.url);    const { pathname } = urlObject;    // api開頭的是API請求    if (pathname.startsWith('/api')) {      // 再判斷路由      if (pathname === '/api/users') {        // 獲取HTTP動詞        const method = req.method;        if (method === 'GET') {          // 寫一個假數據          const resData = [            {              id: 1,              name: '小明',              age: 18            },            {              id: 2,              name: '小紅',              age: 19            }          ];          res.setHeader('Content-Type', 'application/json')          res.end(JSON.stringify(resData));          return;        }      }    }  });

現(xiàn)在我們訪問/api/users就可以拿到用戶列表了:

Node.js中怎么使用原生API實現(xiàn)一個Web服務器

支持靜態(tài)文件

上面說了API請求是以/api開頭,也就是說不是以這個開頭的可以認為都是靜態(tài)文件,不同文件有不同的Content-Type,我們這個例子里面暫時只支持一種.jpg吧。其實就是給我們的if (pathname.startsWith('/api'))加一個else就行。返回靜態(tài)文件需要:

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術社區(qū)

  2.  使用fs模塊讀取文件。

  3.  返回文件的時候根據不同的文件類型設置不同的Content-Type。

所以我們這個else就長這個樣子:

// ... 省略前后代碼 ...  else {    // 使用path模塊獲取文件后綴名    const extName = path.extname(pathname);    if (extName === '.jpg') {      // 使用fs模塊讀取文件      fs.readFile(pathname, (err, data) => {        res.setHeader('Content-Type', 'image/jpeg');        res.write(data);        res.end();      })    }  }

然后我們在同級目錄下放一個圖片試一下:

Node.js中怎么使用原生API實現(xiàn)一個Web服務器

數據持久化

數據持久化的方式有好幾種,一般都是存數據庫,少數情況下也有存文件的。存數據庫比較麻煩,還需要創(chuàng)建和連接數據庫,我們這里不好demo,我們這里演示一個存文件的例子。一般POST請求是用來存新數據的,我們在前面的基礎上再添加一個POST /api/users來新增一條數據,只需要在前面的if (method === 'GET')后面加一個POST的判斷就行:

// ... 省略其他代碼 ...  else if (method === 'POST') {    // 注意數據傳過來可能有多個chunk    // 我們需要拼接這些chunk    let postData = '';    req.on('data', chunk => {      postDatapostData = postData + chunk;    })    req.on('end', () => {      // 數據傳完后往db.txt插入內容      fs.appendFile(path.join(__dirname, 'db.txt'), postData, () => {        res.end(postData);  // 數據寫完后將數據再次返回      });    })  }

然后我們測試一下這個API:

Node.js中怎么使用原生API實現(xiàn)一個Web服務器

再去看看文件里面寫進去沒有:

Node.js中怎么使用原生API實現(xiàn)一個Web服務器

上述就是小編為大家分享的Node.js中怎么使用原生API實現(xiàn)一個Web服務器了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI