精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

使用Node.js原生API寫一個Web服務器

開發 前端
本文要講的就是不借助框架,只用原生API怎么寫一個Web服務器。因為在我的計劃中,后面會寫Express和Koa的源碼解析,他們都是使用原生API來實現的。

Node.js是JavaScript基礎上發展起來的語言,所以前端開發者應該天生就會一點。一般我們會用它來做CLI工具或者Web服務器,做Web服務器也有很多成熟的框架,比如Express和Koa。但是Express和Koa都是對Node.js原生API的封裝,所以其實不借助任何框架,只用原生API我們也能寫一個Web服務器出來。本文要講的就是不借助框架,只用原生API怎么寫一個Web服務器。因為在我的計劃中,后面會寫Express和Koa的源碼解析,他們都是使用原生API來實現的。所以本文其實是這兩個源碼解析的前置知識,可以幫我們更好的理解Express和Koa這種框架的意義和源碼。本文僅為說明原生API的使用方法,代碼較丑,請不要在實際工作中模仿!

本文可運行代碼示例已經上傳GitHub,大家可以拿下來玩玩:https://github.com/dennis-jiang/Front-End-Knowledges/tree/master/Examples/Node.js/HttpServer

Hello World

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

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

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

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

  1.  不支持HTTP動詞,比如GET,POST等
  2.  不支持路由
  3.  沒有靜態資源托管
  4.  不能持久化數據

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

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

處理路由和HTTP動詞

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

  1. const url = require('url');  
  2. const server = http.createServer((req, res) => {  
  3.   // 獲取url的各個部分  
  4.   // url.parse可以將req.url解析成一個對象  
  5.   // 里面包含有pathname和querystring等  
  6.   const urlurlObject = url.parse(req.url);  
  7.   const { pathname } = urlObject;  
  8.   // api開頭的是API請求  
  9.   if (pathname.startsWith('/api')) {  
  10.     // 再判斷路由  
  11.     if (pathname === '/api/users') {  
  12.       // 獲取HTTP動詞  
  13.       const method = req.method;  
  14.       if (method === 'GET') {  
  15.         // 寫一個假數據  
  16.         const resData = [  
  17.           {  
  18.             id: 1,  
  19.             name: '小明',  
  20.             age: 18  
  21.           },  
  22.           {  
  23.             id: 2,  
  24.             name: '小紅',  
  25.             age: 19  
  26.           }  
  27.         ];  
  28.         res.setHeader('Content-Type', 'application/json')  
  29.         res.end(JSON.stringify(resData));  
  30.         return;  
  31.       }  
  32.     }  
  33.   }  
  34. }); 

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

支持靜態文件

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

  1.  使用fs模塊讀取文件。
  2.  返回文件的時候根據不同的文件類型設置不同的Content-Type。

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

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

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

數據持久化

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

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

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

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

總結

到這里我們就完成了一個具有基本功能的web服務器,代碼不復雜,但是對于幫我們理解Node web服務器的原理很有幫助。但是上述代碼還有個很大的問題就是:代碼很丑!所有代碼都寫在一堆,而且HTTP動詞和路由匹配全部是使用if條件判斷,如果有幾百個API,再配合十來個動詞,那代碼簡直就是個災難!所以我們應該將路由處理,HTTP動詞,靜態文件,數據持久化這些功能全部抽離出來,讓整個應用變得更優雅,更好擴展。這就是Express和Koa這些框架存在的意義,下一篇文章我們就去Express的源碼看看他是怎么解決這個問題的,點個關注不迷路~ 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2019-02-15 10:49:37

Node.jsweb服務器

2022-06-05 13:52:32

Node.jsDNS 的原理DNS 服務器

2011-06-17 10:29:04

Nodejavascript

2020-10-12 08:06:28

HTTP 服務器證書

2020-08-07 10:40:56

Node.jsexpress前端

2019-03-15 09:34:18

靜態資源服務器命令前端

2025-07-11 08:09:07

Node.jsAPI權限

2023-01-10 14:11:26

2011-07-26 11:07:08

JavaScript

2011-10-25 09:28:30

Node.js

2022-08-28 16:30:34

Node.jsDocker指令

2022-08-22 07:26:32

Node.js微服務架構

2021-09-02 10:49:25

Node.jsPHP服務器開發

2022-03-08 15:13:34

Fetch APINode.js開發者

2019-08-29 10:58:02

Web 開發框架

2014-04-14 15:54:00

print()Web服務器

2023-04-18 15:18:10

2022-09-12 15:58:50

node.js微服務Web

2011-09-08 10:21:50

Node.js

2014-04-21 14:56:45

NodeJSOAuth2服務器
點贊
收藏

51CTO技術棧公眾號

亚洲欧洲二区| 日韩一级片免费看| 68国产成人综合久久精品| 3d动漫精品啪啪1区2区免费| 亚洲国产一二三精品无码| 亚洲精品国产一区二| 老鸭窝亚洲一区二区三区| 日韩视频免费在线| 国产免费一区二区三区最新6| 欧美xxx性| 一区二区三区欧美日| 欧美视频小说| 黄色福利在线观看| 日韩av一区二区在线影视| 米奇精品一区二区三区在线观看| 黄色a一级视频| 另类视频一区二区三区| 色综合一区二区三区| 成人手机在线播放| av在线免费播放网站| 国产激情一区二区三区四区 | 黄视频网站在线| av亚洲精华国产精华| 91久久精品一区| 国产嫩bbwbbw高潮| 欧美激情第8页| 在线观看亚洲区| 少妇一级淫免费观看| 日本电影久久久| 欧美午夜激情视频| 亚洲色成人www永久在线观看| 午夜看片在线免费| 国产欧美日韩精品在线| 九九九九精品| 欧美 日韩 中文字幕| 国产一二三精品| 国产精品综合网站| 亚洲中文一区二区| 亚洲一区国产一区| 久久久久久久久久久网站| 99久久99久久精品国产| 国产在线日韩精品| 亚洲美女视频网站| 日韩片在线观看| 风间由美一区二区av101| 欧美一级在线观看| 日本r级电影在线观看| 日本黄色成人| 在线成人高清不卡| 亚洲天堂网2018| 日韩欧美激情| 欧美日本在线播放| www.久久av.com| 最新亚洲国产| 日韩一区二区免费电影| 涩多多在线观看| 日韩区欧美区| 亚洲成成品网站| 亚洲色图欧美日韩| 青草久久视频| 国产亚洲精品美女| 四虎国产成人精品免费一女五男| 久久亚洲国产| xxx成人少妇69| 久久中文免费视频| 欧美激情一区| 国内伊人久久久久久网站视频| 精品少妇久久久久久888优播| 亚洲综合中文| 在线观看久久久久久| 免费成人美女女在线观看| 亚洲综合五月| 国内精品国产三级国产在线专| 免费日韩一级片| 日日骚欧美日韩| 亚洲aⅴ日韩av电影在线观看| a级片免费观看| 99久久777色| 日韩欧美一区二区视频在线播放| 欧美另类极品| 亚洲sss视频在线视频| 亚洲国产精品久久久久婷蜜芽| 二区三区不卡| 欧美一区中文字幕| 精品国产av色一区二区深夜久久| 经典一区二区| 免费97视频在线精品国自产拍| 久久久精品人妻一区二区三区四| 国产精品美女久久久| 国产日韩欧美在线看| 风流少妇一区二区三区91| 久久午夜老司机| 日本特级黄色大片| 美女露胸视频在线观看| 欧美性videosxxxxx| 亚洲精品一区二区18漫画| 香蕉视频一区| 久久久精品亚洲| 四虎精品永久在线| 激情综合色综合久久综合| 精品久久久久久乱码天堂| jizz在线观看中文| 亚洲国产精品久久久久秋霞影院 | 成人在线观看免费视频| 日韩你懂的在线播放| 国产中年熟女高潮大集合| 久久久久免费av| 日本精品一区二区三区在线播放视频| 91禁在线观看| 久久一二三国产| 青草全福视在线| 欧美日韩免费看片| 精品sm捆绑视频| 九九热最新地址| 青青草国产精品97视觉盛宴| 国产在线一区二区三区欧美| 麻豆电影在线播放| 在线精品视频免费播放| 亚洲一区二区三区四区五区六区| 中国成人一区| 91精品国产综合久久香蕉922| 亚洲色图21p| 亚洲综合一区二区三区| www.超碰97.com| 国产欧美日韩在线观看视频| 韩剧1988免费观看全集| 国产福利资源在线| 综合激情成人伊人| 在线免费视频a| 亚洲人和日本人hd| 77777亚洲午夜久久多人| www.久久精品.com| 亚洲欧洲日韩av| 91欧美视频在线| 精品一二三区| 国产精品电影一区| 秋霞av在线| 日韩欧中文字幕| mm131美女视频| 裸体一区二区| 欧洲精品一区色| 日本免费一区二区三区四区| 日韩电影视频免费| 日韩高清精品免费观看| 成人毛片视频在线观看| 中文字幕无码精品亚洲资源网久久| 精品久久免费| 欧美高清视频免费观看| 亚洲成人中文字幕在线| 亚洲最快最全在线视频| 污网站免费观看| 精品电影一区| 久久精品国产一区二区三区日韩| 乱馆动漫1~6集在线观看| 亚洲精品电影网| 日韩精品视频免费播放| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 夜夜嗨av一区二区三区四季av| 国产高清999| 91精品一区国产高清在线gif | 刘玥91精选国产在线观看| 亚洲综合色成人| 亚洲少妇中文字幕| 在线精品亚洲| 欧美日韩电影一区二区三区| 韩国精品主播一区二区在线观看| 国产一区二区三区欧美| 国产精品丝袜黑色高跟鞋| 亚洲美女一区二区三区| 美女黄色一级视频| 乱人伦精品视频在线观看| 亚洲二区三区四区| 精品一区二区三区亚洲| 色综合久久精品亚洲国产| 国产夫绿帽单男3p精品视频| 五月婷婷综合激情| 欧美人与性囗牲恔配| 韩国成人福利片在线播放| 国产一区二区四区| 最新亚洲精品| 91久久精品美女| 女人高潮被爽到呻吟在线观看| 国产亚洲精品久久久久动| 国产免费高清视频| 精品福利免费观看| 天堂网av2018| 成人黄色在线视频| 天天干天天爽天天射| 国内一区二区三区| 日韩av不卡播放| 日韩精品一级| 国产精品第100页| 免费在线国产视频| 亚洲天堂一区二区三区| 亚洲毛片在线播放| 欧美视频一区在线观看| 久久久久久久99| 国产精品久久久久久久岛一牛影视| 男人女人拔萝卜视频| 日韩国产欧美在线视频| 久久精品xxx| 欧美先锋资源| 精品国产一区二区三区麻豆免费观看完整版 | 无码 人妻 在线 视频| 国产一区二区三区免费观看| 国产日本欧洲亚洲| 99re在线视频免费观看| 亚洲成人精品| 欧美日韩另类综合| 日韩一二三区| 国产精品亚洲аv天堂网| 国产理论电影在线| www.xxxx欧美| 国家队第一季免费高清在线观看| 欧美大片国产精品| 97精品人妻一区二区三区香蕉| 黑人巨大精品欧美一区二区免费| 劲爆欧美第一页| 国产精品麻豆一区二区 | 91色乱码一区二区三区| 三级性生活视频| 奇米精品一区二区三区在线观看一| 国产免费黄色小视频| 欧美伊人久久| 亚洲日本理论电影| 国产乱码精品一区二区亚洲| 狠狠色噜噜狠狠色综合久| 伊人久久亚洲| av资源一区二区| 欧美专区一区| 91影视免费在线观看| 久久爱.com| 国产精品久久久久久久久久久新郎| 涩涩视频在线播放| 欧美精品在线免费播放| 毛片免费不卡| 久久久999国产| 日韩黄色影院| 日韩在线视频免费观看高清中文| 成人午夜在线观看视频| 亚洲欧美综合图区| 欧美zozo| 一区二区三区四区精品| 国模精品一区二区| 亚洲最新视频在线| 在线中文资源天堂| 中文字幕亚洲色图| 在线视频三区| 久久资源免费视频| 超碰在线观看免费| 欧美成人免费全部| 国产99re66在线视频| 欧美夫妻性生活xx| 美女日批视频在线观看| 午夜精品理论片| 中文字幕人成乱码在线观看| 欧美在线视频观看| 成人开心激情| 国产免费一区二区三区在线观看| www.久久久.com| 俄罗斯精品一区二区| 噜噜噜天天躁狠狠躁夜夜精品| 久久99精品久久久久久水蜜桃| 色狼人综合干| 亚洲高清乱码| 欧美一区国产在线| 成人免费性视频| 久久精品动漫| 色一情一区二区| 国产精品主播直播| 艳妇乳肉亭妇荡乳av| 国产午夜精品福利| 欧美美女性生活视频| 一区二区欧美在线观看| www.av麻豆| 欧美日韩免费观看一区二区三区| 国产www免费观看| 日韩国产欧美精品一区二区三区| 国产香蕉视频在线看| 久久久国产精彩视频美女艺术照福利| 激情网站在线| 国产成人免费av| 国产在线一区不卡| 九九九九九九精品| 美国黄色特级片| 国产精品一区二区在线观看网站| 日韩精品人妻中文字幕有码| 国产欧美日韩激情| 欧美成人片在线观看| 一本到不卡精品视频在线观看| 一级黄色小视频| 亚洲国产精品va在看黑人| 成年人在线看| 久久久亚洲精选| 成人在线观看免费视频| 国产视频不卡| 99久久久久国产精品| 天天夜碰日日摸日日澡性色av| 另类小说一区二区三区| 黄色免费视频网站| 国产精品久久久久久久第一福利| 免费在线观看黄网站| 6080午夜不卡| 久久这里精品| 午夜精品久久久久久99热| 欧美aaaaaa| 欧美日韩亚洲在线| 亚洲黄色一区| 在线免费黄色小视频| 国产亚洲自拍一区| 日韩精品成人在线| 欧美一区二区三区系列电影| 成年人免费在线视频| 91国内精品久久| 综合激情网...| 黄瓜视频免费观看在线观看www | 尤蜜粉嫩av国产一区二区三区| 国产suv精品一区二区三区| 人妻无码一区二区三区免费| 欧美性高潮床叫视频| 日本成人动漫在线观看| 九九久久综合网站| 亚洲伦理久久| 亚洲 国产 日韩 综合一区| 国产亚洲毛片在线| 日本人添下边视频免费| 亚洲激情男女视频| 国产精品嫩草影院精东| 色老头一区二区三区在线观看| 欧美伦理91| 久久久影院一区二区三区 | 97国产精品久久| 日本高清久久| 中文字幕の友人北条麻妃| 精品一区二区成人精品| 熟女av一区二区| 欧美精品少妇一区二区三区| 午夜精品一区| 91网站免费看| 一区二区三区中文| 麻豆传媒在线看| 亚洲免费av观看| 国产黄a三级三级三级| 欧美噜噜久久久xxx| 国产亚洲亚洲国产一二区| 日本黄色播放器| 韩国精品免费视频| 国产精品老熟女一区二区| 欧美一级在线视频| 青春草在线免费视频| 操人视频欧美| 国产情侣一区| a级大片在线观看| 欧美综合亚洲图片综合区| av电影在线播放高清免费观看| 国产日韩欧美视频| 亚洲国产日韩欧美在线| 欧美性猛交乱大交| 午夜激情久久久| 女人天堂在线| 91精品久久久久久久久久久久久久 | 加勒比av一区二区| 免费无码毛片一区二区app| 亚洲精品在线免费播放| 午夜av不卡| 天堂资源在线亚洲资源| 精品一区二区三区av| 妺妺窝人体色www婷婷| 亚洲精品久久久久久久久| 美女一区网站| 日韩视频在线免费播放| 国产91精品一区二区| 天天操天天操天天操天天| 伊人精品在线观看| 欧美午夜在线播放| 国产免费黄色av| 国产精品美女久久久久久久网站| 国产999久久久| 51久久精品夜色国产麻豆| 成人羞羞在线观看网站| 亚洲妇女无套内射精| 欧美日韩一区二区免费在线观看| 亚洲s色大片| 国产福利久久| 奇米色777欧美一区二区| 免费在线观看av网址| 国产一区二区三区四区福利| 国产午夜精品一区在线观看| 大陆极品少妇内射aaaaa| 国产精品久久久久久妇女6080 | 国产美女www爽爽爽| 欧美成人中文字幕| 最新精品国偷自产在线| 中文字幕在线视频一区二区| 色综合中文综合网| 污视频在线看网站| 日韩色妇久久av| 成人h动漫精品一区二区 | 精品国产第一区二区三区观看体验 | 熟妇人妻av无码一区二区三区|