ylbtech-Node.js:Web 模块
1.返回顶部
1、

Node.js Web 模块


什么是 Web 服务器?

Web服务器一般指网站服务器,是指驻留于因特网上某种类型计算机的程序,Web服务器的基本功能就是提供Web信息浏览服务它只需支持HTTP协议、HTML文档格式及URL,与客户端的网络浏览器配合

大多数 web 服务器都支持服务端的脚本语言(php、python、ruby)等,并通过脚本语言从数据库获取数据,将结果返回给客户端浏览器。

目前最主流的三个Web服务器是Apache、Nginx、IIS


Web 应用架构

  • Client - 客户端,一般指浏览器,浏览器可以通过 HTTP 协议向服务器请求数据。

  • Server - 服务端,一般指 Web 服务器,可以接收客户端请求,并向客户端发送响应数据。

  • Business - 业务层, 通过 Web 服务器处理应用程序,如与数据库交互,逻辑运算,调用外部程序等。

  • Data - 数据层,一般由数据库组成。


使用 Node 创建 Web 服务器

Node.js 提供了 http 模块,http 模块主要用于搭建 HTTP 服务端和客户端,使用 HTTP 服务器或客户端功能必须调用 http 模块,代码如下:

var http = require('http');

以下是演示一个最基本的 HTTP 服务器架构(使用 8080 端口),创建 server.js 文件,代码如下所示:

实例

var http = require('http');
var fs = require('fs');
var url = require('url'); // 创建服务器
http.createServer( function (request, response) {
// 解析请求,包括文件名
var pathname = url.parse(request.url).pathname; // 输出请求的文件名
console.log("Request for " + pathname + " received."); // 从文件系统中读取请求的文件内容
fs.readFile(pathname.substr(1), function (err, data) {
if (err) {
console.log(err);
// HTTP 状态码: 404 : NOT FOUND
// Content Type: text/plain
response.writeHead(404, {'Content-Type': 'text/html'});
}else{
// HTTP 状态码: 200 : OK
// Content Type: text/plain
response.writeHead(200, {'Content-Type': 'text/html'}); // 响应文件内容
response.write(data.toString());
}
// 发送响应数据
response.end();
});
}).listen(8080); // 控制台会输出以下信息
console.log('Server running at http://127.0.0.1:8080/');

接下来我们在该目录下创建一个 index.html 文件,代码如下:

index.html 文件

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>
<h1>我的第一个标题</h1>
<p>我的第一个段落。</p>
</body>
</html>

执行 server.js 文件:

$ node server.js
Server running at http://127.0.0.1:8080/

接着我们在浏览器中打开地址:http://127.0.0.1:8080/index.html,显示如下图所示:

执行 server.js 的控制台输出信息如下:

Server running at http://127.0.0.1:8080/
Request for /index.html received. # 客户端请求信息

使用 Node 创建 Web 客户端

Node 创建 Web 客户端需要引入 http 模块,创建 client.js 文件,代码如下所示:

实例

var http = require('http');

// 用于请求的选项
var options = {
host: 'localhost',
port: '8080',
path: '/index.html'
}; // 处理响应的回调函数
var callback = function(response){
// 不断更新数据
var body = '';
response.on('data', function(data) {
body += data;
}); response.on('end', function() {
// 数据接收完成
console.log(body);
});
}
// 向服务端发送请求
var req = http.request(options, callback);
req.end();

新开一个终端,执行 client.js 文件,输出结果如下:

$ node  client.js
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>
<h1>我的第一个标题</h1>
<p>我的第一个段落。</p>
</body>
</html>

执行 server.js 的控制台输出信息如下:

Server running at http://127.0.0.1:8080/
Request for /index.html received. # 客户端请求信息
2、
2.返回顶部
 
3.返回顶部
 
4.返回顶部
 
5.返回顶部
1、
2、
 
6.返回顶部
 
作者:ylbtech
出处:http://ylbtech.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

最新文章

  1. JDK8 的 Lambda 表达式原理
  2. C语言混乱代码大赛
  3. ASP.NET MVC系列 框架搭建(三)之服务层的搭建
  4. JS位操作符
  5. 如何查看和停止Linux启动的服务
  6. java jar
  7. xp默认安装路径及本地用户配置文件存放路径修改
  8. Cocos2d-JS v3.0 alpha 导入 cocostudio的ui配置
  9. 全面理解Linux输入输出重定向
  10. HTML.ActionLink 和Html.Action和 Url.Action 的区别
  11. 创建DBLink语句
  12. DWR异步产生的问题
  13. python8--文件操作 with。。。open语法
  14. [SNOI2017]一个简单的询问
  15. @ResponseBody中文乱码解决方案
  16. three.js学习:初学three.js,从立方体开始
  17. CString int转换
  18. Netty 源码剖析之 unSafe.read 方法
  19. FTP服务器原理(转)
  20. Spring Cloud Config 自动刷新所有节点 架构改造

热门文章

  1. Cell期刊论文:为什么计算机人脸识别注定超越人类?(祖母论与还原论之争)
  2. matlab中 注意事项--字符串
  3. 05-- C++ 类的静态成员详细讲解
  4. (转)淘淘商城系列——Solr集群搭建
  5. sql server 查询数据判断为空
  6. 不能访问windows installer 服务,可能你在安全模式下运行 windows ,或者windows installer
  7. Windows server 2008R2系统登录密码破解
  8. 洛谷P1115 最大子段和【dp】
  9. HAOI2010软件安装(树形背包)
  10. 爬虫系列(十二) selenium的基本使用