上节课我解释了客户端如何发起请求到服务端,还有服务器端如何响应请求给客户端。这节课开始使用 Node.js 来创建属于自己的服务器,然后从客户端发起请求到服务器并让其响应请求。
如何创建服务器呢?超级简单,只需要使用 Node.js 内置的 http
模块。
var http = require('http');
我们可以使用 http
模块里的方法来创建服务器
- 使用
createServer
方法创建服务器 - 每当接收到请求就会执行
createServer 里的回调方法
,而处理请求与响应请求则在回调方法中进行- 参数
req
是装载了来自客户端请求详细信息的对象 - 参数
res
则是我们可以响应给客户端的对象
- 参数
var http = require('http');
var server = http.createServer(function(req, res){
});
头部信息
响应头响应请求之前我们聊聊头部信息,当响应请求的时候,除了响应数据外我们还会响应
头部信息
,而发送请求会则带上请求头。你可以认为头部信息是一种请求或响应信息的额外信息,如 html 页面的 head 块不需要显示,却能让浏览器了解 html 文档的更多信息。
我们可以放这些东西到头部信息里:
-
Content-Type
浏览器所期待内容的类型,可能是纯文本,HTML,JSON,根据不同的类型会有不同的处理方法 -
Status
状态码- 200 是所有都正常
- 404 页面找不到
继续,先创建响应头
然后提供响应的信息
-
创建响应头
的方法writeHead
- 第一个参数是状态,下例为200
- 第二个参数是一个对象,里面添加
Content-Type
,下例为纯文本
-
然后可以
响应内容
到客户端,使用end
方法,这样我们就响应了头部信息与内容
var http = require('http');
var server = http.createServer(function(req, res){
res.writeHead(200, {
'Content-Type': 'text/plain'
});
res.end('Hello world');
});
现在用客户端发送请求还是未能正常工作,因为我们没有指定端口号
。记得吗,上节课有提到我们可以让 Node.js 监听某个端口的请求,因此发送请求前,我们先处理监听的动作。
'app.js'
var http = require('http');
var server = http.createServer(function(req, res){
res.writeHead(200, {
'Content-Type': 'text/plain'
});
res.end('Hello world');
});
server.listen(8888, '127.0.0.1'); // 监听本机上的 8888 端口
console.log('server is listening 8888');
好,这就是服务器相关的配置,现在只要在命令行运行 node app.js
就会看到命令行输出
server is listening 8888
然后在浏览器地址栏上输入 '127.0.0.1:8888',浏览器则会显示 Hello world
,就是服务器返回的内容
打开浏览器开发者工具控制台里的网络面板
,重新刷新一次页面可以在里看到请求,点击该请求能看到有请求与响应面板,响应面板里能看到 Status
与 Content-Type
。
只要浏览器地址上输入 '127.0.0.1:8888',无论后面加什么('127.0.0.1:8888/index.html')都是响应这个内容,实际上我们需要通过 URL 来区分响应内容,这个在接下来的课程会继续讨论。
额外加点东西,我们可以在请求对象里获取一些信息,如请求的 url
var http = require('http');
var server = http.createServer(function(req, res){
console.log(req.url); // 输出客户端输入的 url 地址
res.writeHead(200, {
'Content-Type': 'text/plain'
});
res.end('Hello world');
});
网友评论