一、前言

在"初探nodeJS"随笔中,我们对于node有了一个大致地了解,并在最后也通过一个示例,了解了如何快速地开启一个简单的服务器。
今儿,再次看了该篇随笔,发现该随笔理论知识稍多,适合初级入门node,固萌生一个想法--想在该篇随笔中,通过一步步编写一个稍大一点的node示例,让我们在整体上更加全面地了解node。
so,该篇随笔是建立在"初探nodeJS"之上的,固取名为"进阶之初探nodeJS"。
好了,侃了这多,那么我们即将实现一个什么样的示例呢?
示例说明,如下:
用户通过url之127.0.0.1/login进入登入页面,待用户输入账户名后(密码选项输不输都无所谓,只是为了页面合理),点击提交,进入home页面。
node服务端,怎么处理的呢?通过URL判断,当为/login时,服务端读取login.html的内容,并将其传递到前端显示;当为/home时,服务端读取home.html的内容,并将login.html中提交的账号名与home.html中的模板替换,最后将结果传递到前端显示。
大体流程,如下:
示例最终实现效果,如下:
好了,了解示例需求,下面我们就一起来一步一步实现上述Demo吧。
二、前端文件准备
要实现上述效果,我们首先简单地准备两个页面login.html、home.html以及一张贺岁图片,显而易见,供接下来node读取它们并将它们呈现到浏览器中,使用。
在上述说明中,已讲过node服务器是通过路由来判断,加载哪张页面,固我们将login.html中form的action写作'./home',以达到我们的目的,请求方式嘛,使用的当然是post咯。
且,因为我们要将在login.html中填写的账户名动态地与home.html结合,固home.html中的“称呼”位置,不能写死,因此我们利用{name}来占位,随后利用node动态替换。
好了,简易编写的login.html、home.html以及贺岁图,如下:
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<style>
form {
text-align:center;
}
</style>
</head>
<body>
<form action="./home" method="post">
账户:<input type="text" name="name"/><br/>
密码:<input type="password" name="password"/><br/>
<input type="submit" value="提交"/>
</form>
</body>
</html>
login.html
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<style>
body {
text-align:center;
}
span {
color: blue;
}
</style>
</head>
<body>
<div>
<span>{name}</span>,新de一年,一定要开心哦~
</div>
<img src="./getPic"/>
</body>
</html>
home.html
三、编写node服务
上述中,我们所需要的前端文件已经准备完毕,接下来就是通过node来编写服务,将它们串联起来咯。
首先,我们搭建一个主文件,取名为main.js吧,作用不言而喻,主入口嘛,如果我们在代码编写完毕后,想要启动服务,就node main.js就OK咯。
如下:
'use strict';
var http = require('http');
var server = http.createServer();
server.on('request',function(req, res){
//排除favicon.ico请求
if(req.url != '/favicon.ico'){
//TODO
}else{
res.end();
};
}).listen('80');
console.log('Server running!');
接着,我们就一起来逐步完善这个主文件。
在“前言”中我们提过,当一个请求来到服务中,我们采取获取URL的路径,来判断接下来的操作,已到达降低耦合性的目的。
所以,在主程序中,我们得利用url这个模块,来获得url中的相关路径,并通过正则来得到第一个路径名,通过接下来的路由模块,处理。
如下:
'use strict';
var http = require('http');
var url = require('url');
var server = http.createServer();
server.on('request',function(req, res){
if(req.url != '/favicon.ico'){
//获取路径
let pathname = url.parse(req.url).pathname;
pathname = pathname.match(/\w+/)[0];
//router具体,待写...
router[pathname](req, res);
}else{
res.end();
};
}).listen('80');
console.log('Server running!');
好了,接下来,我们就一起来编写router这个模块吧。
在我们示例中,router无外乎就是处理login、home以及图片请求getPic,所以,我们将router模块基本骨架,暂定如下:
'use strict';
var router = {
login: function(req, res){
//TODO
},
home: function(req, res){
//TODO
},
getPic: function(req, res){
//TODO
}
};
module.exports = router;
且,我们发现login、home以及getPic这三个操作,有很多共通之处,如都会读取服务端本地文件,以及将读取的文件,写入响应体中,固我们将这些操作提取出来,作为operation模块。
在operation模块中,我们需要使用到node内置'fs'这个模块来读取文件,'fs'模块我们将会用到如下方法:
1、fs.readFileSync--同步读取文件
2、fs.readFile--异步读取文件
3、fs.writeFileSync--同步写入文件
4、fs.writeFile--异步写入文件
需要注意的是,读取图片也就使用的fs.readFileSync/fs.readFile,不过就是第二个参数还需加上'binary',二进制嘛。
'use strict';
var fs = require('fs');
var operationFile = {
readFileSync: function(path, callback){//同步读取文件
let data = fs.readFileSync(path, 'utf-8');
syncOperation(callback, data, '同步读取文件完毕');
},
readFileAsync: function(path, callback){//异步读取文件
fs.readFile(path, function(err, data){
asyncOperation(err, callback, data, '异步读取文件成功');
});
},
writeFileSync: function(path, data, callback){//同步写入文件
fs.writeFileSync(path, data);
syncOperation(callback, null, '同步写入文件完毕');
},
writeFile: function(path, data, callback){//异步写入文件
fs.writeFile(path, data, function(err){
asyncOperation(err, callback, null, '异步写入文件完毕');
});
},
readImg: function(path, callback){//异步读取图片
fs.readFile(path, 'binary', function(err, file){
asyncOperation(err, callback, file, '异步读取图片完毕');
});
}
};
function syncOperation(callback, data, msg='操作成功'){
if(typeof callback === 'function'){
callback(data);
}else{
console.log(msg);
}
}
function asyncOperation(err, callback, data, msg='操作成功'){
if(err){
console.log(err);
}else if(typeof callback === 'function'){
callback(data);
}else{
console.log(msg);
}
}
module.exports = operationFile;
operation模块
另外,我们在login.html中提交表单时,使用到了post请求,那么在node服务中应该怎么接收传来的实体呢?
node是采用的监听'data'来接收post方法实体信息,通过'end'来监听接收信息完毕事件。
而,node接收get请求参数就没这么复杂,直接获取url后的查询字符串即可。
好了,我们将获取post、get请求参数,也写为一个模块,取名为getQuery,如下:
'use strict';
var url = require('url');
var querystring = require('querystring');
module.exports = {
fromGet: function(req, res, callback){
var data = url.parse(req.url, true).query;
callback(data);
},
fromPost: function(req, res, callback){
var data = '';
req.on('data', function(chunk){
data += chunk;
});
req.on('end', function(){
data = querystring.parse(data);
callback(data);
});
}
};
getQuery模块
最后,就是在router模块中,引入operation、getQuery模块,完善login、home以及getPic方法咯。
在这里需要注意的是getPic方法,因为是处理的图片,所以响应头得写成'image/jpeg',如下:
res.writeHead(200, {'Content-Type':'image/jpeg'});
好了,大致思路已理清,详细代码请见github.
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# nodeJS
# 简单实现nodejs上传功能
# 基于NodeJS+MongoDB+AngularJS+Bootstrap开发书店案例分析
# nodejs实例解析(输出hello world)
# Highcharts+NodeJS搭建数据可视化平台示例
# nodejs利用http模块实现银行卡所属银行查询和骚扰电话验证示例
# nodeJS删除文件方法示例
# 学习 NodeJS 第八天:Socket 通讯实例
# 详解Nodejs基于mongoose模块的增删改查的操作
# nodejs连接mongodb数据库实现增删改查
# Nodejs 搭建简单的Web服务器详解及实例
# NodeJS实现客户端js加密
# 详解NodeJs支付宝移动支付签名及验签
# 好了
# 服务端
# 的是
# 并将
# 需要注意
# 当为
# 进阶
# 在这里
# 看了
# 让我们
# 也就
# 将会
# 有很多
# 无外乎
# 之处
# 主程序
# 并在
# 就没
# 发现该
# 第二个
相关文章:
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
非常酷的网站设计制作软件,酷培ai教育官方网站?
制作电商网页,电商供应链怎么做?
定制建站流程解析:需求评估与SEO优化功能开发指南
如何在宝塔面板创建新站点?
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
建站之星下载版如何获取与安装?
建站之星导航如何优化提升用户体验?
如何快速搭建高效可靠的建站解决方案?
如何在橙子建站上传落地页?操作指南详解
html制作网站的步骤有哪些,iapp如何添加网页?
b2c电商网站制作流程,b2c水平综合的电商平台?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
文字头像制作网站推荐软件,醒图能自动配文字吗?
制作网站的过程怎么写,用凡科建站如何制作自己的网站?
简易网站制作视频教程,使用记事本编写一个简单的网页html文件?
宝塔建站教程:一键部署配置流程与SEO优化实战指南
如何用虚拟主机快速搭建网站?详细步骤解析
小程序网站制作需要准备什么资料,如何制作小程序?
C#如何在一个XML文件中查找并替换文本内容
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
建站org新手必看:2024最新搭建流程与模板选择技巧
如何基于云服务器快速搭建个人网站?
宝塔面板创建网站无法访问?如何快速排查修复?
Android自定义listview布局实现上拉加载下拉刷新功能
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
宝塔面板如何快速创建新站点?
建站主机是否属于云主机类型?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
代刷网站制作软件,别人代刷火车票靠谱吗?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
c++怎么用jemalloc c++替换默认内存分配器【性能】
如何用已有域名快速搭建网站?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
建站之星2.7模板:企业网站建设与h5定制设计专题
建站之星备案是否影响网站上线时间?
济南网站制作的价格,历城一职专官方网站?
如何彻底删除建站之星生成的Banner?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
如何在阿里云通过域名搭建网站?
香港服务器租用费用高吗?如何避免常见误区?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
家庭服务器如何搭建个人网站?
建站之星代理费用多少?最新价格详情介绍
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
建站10G流量真的够用吗?如何应对访问高峰?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
*请认真填写需求信息,我们会在24小时内与您取得联系。