node.js入门 - 9.api:http

简介:   node一个重要任务是用来创建web服务,接下来我们就学习与此相关的一个重要的api -- http。我们使用http.createServer()创建一个http服务的实例,用来处理来自客户的请求。
+关注继续查看

  node一个重要任务是用来创建web服务,接下来我们就学习与此相关的一个重要的api -- http。我们使用http.createServer()创建一个http服务的实例,用来处理来自客户的请求。http模块包含一些重要的内容,下面我们就来学习。

  

  http服务器

  我们先来看一个简单的例子,如何创建一个简单的服务器。

require('http').createServer(function(req,res){
  res.writeHead(200, {});   res.end('hello world');}
).listen(8125);

  上面的代码比较简单,使用require('http')创建了一个http的实例,然后使用createServer方法创建了一个服务器,使用listen监听8125端口。上面的代码使用了链式的编码风格,虽然简单但是可读性差,变量复用性也不好,所以我们建议使用下面的编码风格。

var http = require('http');
var server = http.createServer();
var handleReq = function(req,res){
  res.writeHead(200, {});
  res.end('hello world');
};
server.on('request', handleReq);
server.listen(8125);

  现在的代码就明了多了,通过 var server = http.createServer() 创建了服务器,并把它保存在变量server中,接下来使用server.on('request', handleReq)绑定request事件。对request事件的绑定,例1链式风格的编码并没能直接体现出来。

  http提供了很多其他的事件,下面我们简单介绍。

  1.connection和close:分别代表建立和关闭与客户端的tcp连接。

  2.checkContinue:当客户端向服务器端发送大量数据的时候,他将检查是否可以继续,此时触发事件。当触发了checkContinue事件时,request事件不再触发。

  3.upgrade:当客户端请求升级协议的时候触发,如果该事件没有相应的处理,服务器将拒绝升级。

  4.clientError:客户端发生异常时触发。

 

  http客户端

  有时候你需要使用到向外连接的http请求,例如使用web服务,访问文本数据源或者抓取web站点信息,这时你可以使用http.ClientRequest创建http请求。先看一个例子:

var http = require('http');
var opts = {
  host: 'www.google.com'
  port: 80,
  path: '/',
  method: 'GET'
};
var req = http.request(opts, function(res) {
  console.log(res);
  res.on('data', function(data) {
    console.log(data);
  });
});
req.end();

  我们创建了一个http请求,为响应添加了data事件,最后使用req.end()初始化和发送我们的请求。

  

  创建http GET 请求

var http = require('http');
var opts = {
  host: 'www.google.com'
  port: 80,
  path: '/',
};
var req = http.get(opts, function(res) {
  console.log(res);
  res.on('data', function(data) {
    console.log(data);
  });
});

  这个例子和之前的例子实现同样的功能,区别就在于opts对象少了method属性,使用http.get()代替了之前的var req=http.request()和req.end()。由于返回回来的数据是2进制数据,我们需要使用response.setEncoding()实现编码,所以我们需要对代码做点小修改。

var http = require('http');
var opts = {
  host: 'www.google.com'
  port: 80,
  path: '/',
};
var req = http.get(opts, function(res) {
  console.log(res);
  res.setEncoding('utf8');   res.on(
'data', function(data) {     console.log(data);   }); });

 

  使用http POST和PUT发送数据

var options = {
  host: 'www.example.com',
  port: 80,
  path: '/submit',
  method: 'POST'
};
var req = http.request(options, function(res) {
  res.setEncoding('utf8');
  res.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
  });
});
req.write("my data");
req.write("more of my data");
req.end();

  上面的例子我们使用了req.write()方法,向服务器说明我们要发送的数据,最后使用req.end()初始化并发送请求。代码中的res是ClientResponse对象,他有两个重要的属性:statusCode(状态码)和header(响应头)。

 

  URL

  url模块提供了一些方法,让我们解析和处理url字符串变得更加简单,这些方法包括:parse, format和resolve。我们来看例子,逐行在node REPL中执行下面的命令(之前的课程讲到了如何使用,node.js入门 - 8.api:events)。

var URL = require('url');
var myUrl = "http://www.nodejs.org/some/url/?with=query&param=that&are=awesome#alsoahash";
myUrl
parsedUrl = URL.parse(myUrl);
parsedUrl = URL.parse(myUrl, true);

  执行结果:

 

   querystring

  querystring模块式用来处理querystring字符串的,他包括如下方法:parse, decode, escape, unescape, unescapeBuffer, encode和stringify。我们来看一个例子。

var qs = require('querystring');
qs.parse('a=1&b=2&c=d');

  执行结果:

   再来一例,关于encode方法。

var qs = require('querystring');
var myObj = {'a':1, 'b':5, 'c':'cats', 'func': function(){console.log('dogs')}}
qs.encode(myObj);

  执行结果:

adpics.aspx?source=kbh1983&sourcesuninfo
目录
相关文章
|
8天前
|
JSON JavaScript 前端开发
使用API接口获取商品数据:从入门到实践
随着电子商务的飞速发展,许多电商平台提供了API接口,允许开发者获取商品数据,以创建各种创新的应用。本文将详细介绍如何使用API接口获取商品数据,并通过代码示例进行演示。
|
2月前
|
开发框架 JSON 前端开发
ASP.NET Web API入门介绍(一)
ASP.NET Web API入门介绍(一)
39 0
|
3月前
|
JSON 程序员 API
Python API教程:API入门
一个API,或被称为应用程序接口,是一个服务器为你提供一个接收或发送数据的代码。API通常用来接收数据。 本文就集中焦点在此话题中。 当我们想从一个API中接收数据,我们需要开始请求。请求可以包含整个Web。例如,你可以浏览博客文章。你的浏览器开始请求我们的Web服务器,会返回整个网页内容。
|
4月前
|
API
zookeeper入门到精通07——zookeeper客户端API节点操作与原理
zookeeper入门到精通07——zookeeper客户端API节点操作与原理
|
4月前
|
Java API Maven
zookeeper入门到精通06——zookeeper客户端API创建节点
zookeeper入门到精通06——zookeeper客户端API创建节点
|
4月前
|
API Windows
刘金玉的零基础VB教程073期:windows API使用入门 sleep
刘金玉的零基础VB教程073期:windows API使用入门 sleep
|
5月前
|
移动开发 数据可视化 前端开发
WebAudio API 入门
之前也有做过前端音频相关的操作,之前的做法是创建一个 audio 标签,需要播放提示音时调用 audio 实例的 play 方法,从而实现提示音的效果。
71 0
|
8月前
|
应用服务中间件 API 容器
Servlet入门案例(三)Servlet的生命周期、api和请求方式、工作原理、注解开发
Servlet入门案例(三)Servlet的生命周期、api和请求方式、工作原理、注解开发
65 0
Servlet入门案例(三)Servlet的生命周期、api和请求方式、工作原理、注解开发
|
8月前
|
JSON JavaScript 前端开发
JQuery JavaScript常用API整理(前端入门必学)
JQuery JavaScript常用API整理(前端入门必学)
|
8月前
|
Web App开发 JSON JavaScript
Node 入门:API、HTTP 和 ES6+ JavaScript 简介
Node 入门:API、HTTP 和 ES6+ JavaScript 简介
65 0
相关产品
云迁移中心
推荐文章
更多