草庐IT

Node.js基础入门第七天

老码识途 2023-03-28 原文

经过前面六天的知识学习,对Node.js开发的基础知识,有了一个初步的掌握,今天继续学习Node.js后端web开发的相关知识,本篇文章作为Node.js服务端程序开发的基础入门知识,仅供学习分享使用,如有不足之处,还请指正。

创建服务端程序

通过Node.js创建web服务端程序,需要引用http模块,创建服务,并监听对应端口,如下所示:

 1 //1.引入http模块
 2 var http  = require('http');
 3 //2.创建服务
 4 var server = http.createServer();
 5 
 6 //3. 监听请求事件,当有请求时,触发回调函数
 7 server.on('request',function(req,res){
 8     //req:请求对象,包含了客户端请求的数据,请求头,请求体
 9     //res:响应对象,包含了所有服务端发送给客户端的数据,响应头,响应体
10     res.writeHead(200,{"content-type":"text/html;charset=utf-8"})
11     res.write("<h3>Hello,Node.js</h3>");
12     res.write("<span>I'am 小六公子</span>");
13     res.end();
14 });
15 
16 //4. 监听8080端口
17 server.listen(8080,function(){
18     console.log("server is running");
19 });

在命令行窗口运行程序,即可启动服务,示例如下:

在浏览器中,输入网址http://http://localhost:8080/,如下则表示成功。

 注意:响应对象同时也是一个流对象,在最后一定要结束流。

端口查看

通过命令行输入netstat -abo可以查看启动端口的程序和进程ID,如下所示:

 

按请求路径响应内容

通过以上示例不难发现,创建web服务,只需要四步。但是在真实的需求中,会有不同的页面,那如何根据不同路径,返回不同内容呢?

后端程序可以根据访问的req.url属性,来判断用户访问的具体页面信息,来做出不同的响应,具体如下所示:

 1 //3. 监听请求事件,当有请求时,触发回调函数
 2 server.on('request',function(req,res){
 3     res.writeHead(200,{"content-type":"text/html;charset=utf-8"});
 4     console.log(req.url);
 5     if(req.url==="/"){
 6         res.write("<span>这是首页</span>");
 7     }
 8     if(req.url==="/list.html"){
 9         res.write("<span>这是列表页</span>");
10     }
11     if(req.url==="/detail.html"){
12         res.write("<span>这是明细页</span>");
13     }
14     res.write("<br /><span>I'am 小六公子</span>");
15     res.end();
16 });

运行程序,如下所示:

打开浏览器,分别输入网址进行测试,如下所示:

状态码

状态码是http协议规定的服务器响应数据时的状态编码。常用的状态码如下所示:

  • 200 请求响应成功
  • 304 未修改,所请求的资源未更改
  • 404 请求的资源不存在。
  • 500 服务器内部错误。

其他状态码可参考百度百科,如下所示:

在Node.js中通过res.writeHead方法,可以返回响应头信息,其中包含状态码,如下所示:

1 server.on('request',function(req,res){
2     res.writeHead(200,{"content-type":"text/html;charset=utf-8"});
3     res.write("<span>这是首页</span>");
4     res.end();
5 });

在浏览器中,进行访问,通过监控网络即可查看状态码,即可返回消息头,如下所示:

 

 如果程序内出现错误,则可以返回500错误,如下所示:

 1 server.on('request',function(req,res){
 2     res.writeHead(200,{"content-type":"text/html;charset=utf-8"});
 3     try{
 4         var t =a+1;
 5         res.write("<span>这是首页"+t+"</span>");
 6     }catch(e){
 7         res.writeHead(500,{"content-type":"text/html;charset=utf-8"});
 8     }
 9     res.end();
10 });

在浏览器打开,如下所示:

响应头

状态码是保存在响应头中的,响应头中不仅包含状态码,还包含其他内容。如下所示:

  • Content-Type响应内容的格式类型,常用Content-Type: text/html;charset=utf-8。
  • Content-Length:响应内容的长度,一般不设置,默认即可。
  • Access-Control-Allow-Origin 响应头跨域设置,默认可以设置成*号。
  • Access-Control-Allow-Methods: POST, GET, OPTIONS, DELETE
  • Access-Control-Max-Age: 86400

响应头示例如下所示:

1 server.on('request',function(req,res){
2     res.writeHead(200,{
3         "content-type":"text/html;charset=utf-8",
4         "Access-Control-Allow-Origin":"*",
5         "Access-Control-Allow-Methods":"POST, GET, OPTIONS, DELETE",
6         "Access-Control-Max-Age":86400});
7     res.write("<span>这是首页</span>");
8     res.end();
9 });

在浏览器中运行,并打开开发者工具进行监控,可以非常方便的查看响应头信息,如下所示:

 

 

构建静态网站

通过以上示例,可以看出,创建一个web服务器端程序,非常简洁,但是以上示例都是在js后端代码中,内嵌html代码,那如何实现代码分离呢?以下以静态网站为例,如下所示:

首先创建静态html页面,如下所示:

 

 

 创建web服务程序,根据请求的url路径,自动读取对应的html页面文件内容并返回,如下所示:

 1 //1.引入http模块
 2 var http  = require('http');
 3 var fs = require('fs');
 4 var path = require('path');
 5 //2.创建服务
 6 var server = http.createServer();
 7 var extnames = {".html":"text/html",".css":"text/css",".png":"image/png"};
 8 //3. 监听请求事件,当有请求时,触发回调函数
 9 server.on('request',function(req,res){
10     
11     var url=req.url;
12     if(url==="/"){
13         url="/index.html";
14     }
15     var localPath = './www'+url;
16     var extname = path.extname(localPath);
17     console.log(localPath);
18     if(extname===".ico"){
19         res.end();
20     }else{
21         fs.readFile(localPath,function(err,data){
22             res.writeHead(200,{"content-type":""+extnames[extname]+";charset=utf-8"});
23             res.write(data);
24             res.end();
25         });
26     }
27 });
28 
29 //4. 监听8080端口
30 server.listen(8080,function(){
31     console.log("server is running");
32 });

运行程序,如下所示:

 

 

 在浏览器中进行访问,如下所示:

备注

登金陵凤凰台【作者】李白 【朝代】唐

凤凰台上凤凰游,凤去台空江自流。

吴宫花草埋幽径,晋代衣冠成古丘。

三山半落青天外,二水中分白鹭洲。

总为浮云能蔽日,长安不见使人愁。

有关Node.js基础入门第七天的更多相关文章

  1. postman接口测试工具-基础使用教程 - 2

    1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,

  2. 软件测试基础 - 2

    Ⅰ软件测试基础一、软件测试基础理论1、软件测试的必要性所有的产品或者服务上线都需要测试2、测试的发展过程3、什么是软件测试找bug,发现缺陷4、测试的定义使用人工或自动的手段来运行或者测试某个系统的过程。目的在于检测它是否满足规定的需求。弄清预期结果和实际结果的差别。5、测试的目的以最小的人力、物力和时间找出软件中潜在的错误和缺陷6、测试的原则28原则:20%的主要功能要重点测(eg:支付宝的支付功能,其他功能都是次要的)80%的错误存在于20%的代码中7、测试标准8、测试的基本要求功能测试性能测试安全性测试兼容性测试易用性测试外观界面测试可靠性测试二、质量模型衡量一个优秀软件的维度①功能性功

  3. LC滤波器设计学习笔记(一)滤波电路入门 - 2

    目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称

  4. 微信小程序开发入门与实战(Behaviors使用) - 2

    @作者:SYFStrive @博客首页:HomePage📜:微信小程序📌:个人社区(欢迎大佬们加入)👉:社区链接🔗📌:觉得文章不错可以点点关注👉:专栏连接🔗💃:感谢支持,学累了可以先看小段由小胖给大家带来的街舞👉微信小程序(🔥)目录自定义组件-behaviors    1、什么是behaviors    2、behaviors的工作方式    3、创建behavior    4、导入并使用behavior    5、behavior中所有可用的节点    6、同名字段的覆盖和组合规则总结最后自定义组件-behaviors    1、什么是behaviorsbehaviors是小程序中,用于实现

  5. 【Java入门】使用Java实现文件夹的遍历 - 2

    遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg

  6. ES基础入门 - 2

    ES一、简介1、ElasticStackES技术栈:ElasticSearch:存数据+搜索;QL;Kibana:Web可视化平台,分析。LogStash:日志收集,Log4j:产生日志;log.info(xxx)。。。。使用场景:metrics:指标监控…2、基本概念Index(索引)动词:保存(插入)名词:类似MySQL数据库,给数据Type(类型)已废弃,以前类似MySQL的表现在用索引对数据分类Document(文档)真正要保存的一个JSON数据{name:"tcx"}二、入门实战{"name":"DESKTOP-1TSVGKG","cluster_name":"elasticsear

  7. ruby-on-rails - Assets 管道损坏 : Not compiling on the fly css and js files - 2

    我开始了一个新的Rails3.2.5项目,Assets管道不再工作了。CSS和Javascript文件不再编译。这是尝试生成Assets时日志的输出:StartedGET"/assets/application.css?body=1"for127.0.0.1at2012-06-1623:59:11-0700Servedasset/application.css-200OK(0ms)[2012-06-1623:59:11]ERRORNoMethodError:undefinedmethod`each'fornil:NilClass/Users/greg/.rbenv/versions/1

  8. ruby-on-rails - Rails - 理解 application.js 和 application.css - 2

    rails新手。只是想了解\assests目录中的这两个文件。例如,application.js文件有如下行://=requirejquery//=requirejquery_ujs//=require_tree.我理解require_tree。只是将所有JS文件添加到当前目录中。根据上下文,我可以看出requirejquery添加了jQuery库。但是它从哪里得到这些jQuery库呢?我没有在我的Assets文件夹中看到任何jquery.js文件——或者直接在我的整个应用程序中没有看到任何jquery.js文件?同样,我正在按照一些说明安装TwitterBootstrap(http:

  9. node.js - 如何在 Travis CI 上的一个项目中运行 Node.js 和 Ruby 测试 - 2

    我有一个包含多个组件的存储库,其中大部分是用JavaScript(Node.js)编写的,一个是用Ruby(RubyonRails)编写的。我想要一个.travis.yml文件来触发一个运行每个组件的所有测试的构建。根据thisTravisCIGoogleGroupthread,目前还没有官方支持。我的目录结构是这样的:.├──构建服务器├──核心├──扩展├──网络应用├──流浪文件├──package.json├──.travis.yml└──生成文件我希望能够运行特定版本的Ruby(2.2.2)和Node.js(0.12.2)。我已经有了一个make目标,所以maketest在每

  10. 【网络】-- 网络基础 - 2

    (本文是网络的宏观的概念铺垫)目录计算机网络背景网络发展认识"协议"网络协议初识协议分层OSI七层模型TCP/IP五层(或四层)模型报头以太网碰撞路由器IP地址和MAC地址IP地址与MAC地址总结IP地址MAC地址计算机网络背景网络发展        是最开始先有的计算机,计算机后来因为多项技术的水平升高,逐渐的计算机变的小型化、高效化。后来因为计算机其本身的计算能力比较的快速:独立模式:计算机之间相互独立。    如:有三个人,每个人做的不同的事物,但是是需要协作的完成。    而这三个人所做的事是需要进行协作的,然而刚开始因为每一台计算机之间都是互相独立的。所以前面的人处理完了就需要将数据

随机推荐