HTTP系列 -- Node.js

Node.js 服务器代码

精华

let string = fs.readFileSync( '路径', 'UTF-8' )
response.setHeader( 'Content-Type', '类型' )
response.statusCode = 200
response.write()
response.end()

response.setHeader( 'Content-Type', '类型' )

类型:

  • HTML ==> response.setHeader( 'Content-Type', 'text/html; charset = utf-8' )
  • CSS ==> response.setHeader( 'Content-Type', 'text/css' )
  • JavaScript ==> response.setHeader( 'Content-Type', 'application/javascript' )

创建 Node.js 服务器

var http = require('http')
var fs = require('fs')
var url = require('url')
var port = process.argv[2]

if(!port){
  console.log('请指定端口号好不啦?\nnode server.js 8888 这样不会吗?')
  process.exit(1)
}

var server = http.createServer(function(request, response){
  var parsedUrl = url.parse(request.url, true)
  var path = request.url 
  var query = ''
  if(path.indexOf('?') >= 0){ query = path.substring(path.indexOf('?')) }
  var pathNoQuery = parsedUrl.pathname
  var queryObject = parsedUrl.query
  var method = request.method



  console.log('HTTP 路径为\n' + path)
  if(path == '/style'){
    response.setHeader('Content-Type', 'text/css; charset=utf-8')
    response.write('body{background-color: #ddd;}h1{color: red;}')
    response.end()
  }else if(path == '/script'){
    response.setHeader('Content-Type', 'text/javascript; charset=utf-8')
    response.write('alert("这是JS执行的")')
    response.end()
  }else if(path == '/index'){
    response.setHeader('Content-Type', 'text/html; charset=utf-8')
    response.write('<!DOCTYPE>\n<html>'  + 
      '<head><link rel="stylesheet" href="/style">' +
      '</head><body>'  +
      '<h1>你好</h1>' +
      '<script src="/script"></script>' +
      '</body></html>')
    response.end()
  }else{
    response.statusCode = 404
    response.end()
  }

})

server.listen(port)
console.log('监听 ' + port + ' 成功\n请用在空中转体720度然后用电饭煲打开 http://localhost:' + port)

解析 Node.js 服务器

  1. console.log('HTTP 路径为\n' + path) 表示在命令行中或者Console面板中打印出当前请求的 HTTP 路径

  2. 下方代码表示如果请求路径为/style,设置响应头信息为'Content-Type', 'text/css; charset=utf-8'(即响应内容 [ 第四部分 ] 的类型 [ css ] 和编码 [ utf-8 ]),响应内容( 第四部分 )为 body{background-color: #ddd;}h1{color: red;} ,之后完成响应

    if(path == '/style'){
        response.setHeader('Content-Type', 'text/css; charset=utf-8')
        response.write('body{background-color: #ddd;}h1{color: red;}')
        response.end()
      }
    
  3. 下方代码表示如果请求路径为 /script ,设置响应头信息为 'Content-Type', 'text/javascript; charset=utf-8' (即响应内容 [ 第四部分 ] 的类型 [ javascript ] 和编码 [ utf-8 ]),响应内容( 第四部分 )为 alert("这是JS执行的"),之后完成响应

    if(path == '/script'){
        response.setHeader('Content-Type', 'text/javascript; charset=utf-8')
        response.write('alert("这是JS执行的")')
        response.end()
      }
    
  4. 下方代码表示如果请求路径为 /index ,设置响应头信息为 ('Content-Type', 'text/html; charset=utf-8' (即响应内容 [ 第四部分 ] 的类型 [ html ] 和编码 [ utf-8 ]),响应内容( 第四部分 )为 HTML 页面,之后完成响应

    if(path == '/index'){
        response.setHeader('Content-Type', 'text/html; charset=utf-8')
        response.write('<!DOCTYPE>\n<html>'  + 
          '<head><link rel="stylesheet" href="/style">' +
          '</head><body>'  +
          '<h1>你好</h1>' +
          '<script src="/script"></script>' +
          '</body></html>')
        response.end()
      }
    
  5. 下方代码表示如果请求的路径不是上述路径,则返回状态码为 404 ,之后完成响应。

    else{
        response.statusCode = 404
        response.end()
      }
    

创建过程

  1. 新建目录和进入

    mkdir node-demo
    cd node-demo
    
  2. 创建文件并编辑

    touch server.js
    start server.js //内容如上
    
  3. 运行文件

    node server.js 端口号
    

使用 Node.js 发起请求

  1. 在新的 Bash 窗口运行 curl http://localhost:你的指定的端口/xxx 或者 curl http://127.0.0.1:你指定的端口/xxx即可发起请求

  2. 在浏览器窗口地址栏中输入 http://localhost:你的指定的端口/xxx 或者 http://127.0.0.1:你指定的端口/xxx 回车,即可发起请求。

  3. curl -s -v -- "http://localhost:port/xxx"可以查看完整的请求体和响应体。

响应

  • 在运行 node server.js 端口号 Bash 窗口中可以查看到打印出来的路径(console.log('HTTP 路径为\n' + path)),并且在发起请求的 Bash 窗口中可以查看请求体和响应体

  • 在浏览器窗口中可以看到实际运行效果

相关知识点

  1. 任意一台电脑都是服务器

  2. 创建的Node.js服务器提供 HTTP 服务,所以需要提供 HTTP 服务的程序

  3. 用脚本可以提供 HTTP 服务

当在浏览器地址栏输入地址回车后发生的事情

  1. DNS 域名解析。首先浏览器会查找缓存,如果没有,就向运营商查找,运营商会提供 DNS 服务,从而得到域名所对应的 IP 地址。DNS 域名解析就是一个域名到 IP 地址的转换
  2. TCP 连接。浏览器根据 IP 地址向服务器发起 TCP 连接,与服务器建立 TCP 三次握手,浏览器对服务器说:“您好,我可以链接你么?”,服务器对浏览器说:“您好,你可以连接我”,浏览器对服务器说:“好的,那我连接你了!”,通过 TCP 的三次握手,从而确定双方都有收发文件的能力,自此浏览器和服务器建立了链接
  3. 浏览器发送 HTTP 请求。请求包括了请求行、请求头和请求正文
  4. 服务器接收请求、处理并返回响应。响应包括了状态码、响应头和响应正文
  5. 浏览器拿到响应、解析并渲染页面。浏览器是一个边解析边渲染的过程,首先浏览器解析HTML文件构建 DOM 树,然后解析 CSS 文件构建渲染树,等到渲染树构建完成后,浏览器开始布局渲染树并将其绘制到屏幕上
  6. 通过四次挥手关闭 TCP 连接。浏览器对服务器说:“不早了,我该走了”,服务器对浏览器说:“知道了”,之后服务器又对浏览器说:“我也该走了”,浏览器回应服务器:“好的”,至此 TCP 连接结束
1. 浏览器检查域名,如果缺少端口号,加上默认的端口号 `80` ,如果缺少路径,加上默认路径 `/` ,如果缺少协议,加上默认协议 `http` 
2. 浏览器将请求的域名发送给路由器。
3. 路由器拿到请求的域名后询问服务商此域名所对应的 IP 地址(服务商的 **DNS** 服务)。
4. 路由器拿到相应的 IP 地址,发起 HTTP 请求(**Request Headers**)。
5. 相应 IP 地址的服务器将在 80 端口接收路由器的请求。
6. 服务器查看路径,`setHeader` ,之后返回 `HTML` 。
7. 服务器响应并返回内容给路由器。
8. 路由器接收响应(内容)。
9. 路由器将响应(内容)传递给浏览器。
10. 浏览器下载相应的 `HTML` 。
11. 浏览器解析,并查看是否还有要请求的东西,如果有,再次发起 `HTTP` 请求。
12. 所有的东西都请求结束,浏览器渲染到页面。

注意:后缀是没有用的。HTTP 路径不是文件路径。

需要强化的知识点

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,039评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,426评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,417评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,868评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,892评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,692评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,416评论 3 419
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,326评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,782评论 1 316
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,957评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,102评论 1 350
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,790评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,442评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,996评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,113评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,332评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,044评论 2 355