nodejs搭建本地http服务器教程
发布时间 - 2026-01-11 00:08:08 点击率:次由于不做php相关的东西,懒得装apache,干脆利用nodejs搭建一个本地的服务器用于测试。

nodejs这玩意儿吧,对做前端的介入后端简直就是一把利器。而且目前,nodejs也越来越有商用价值。
nodejs其实是非常底层的,从功能上说,它既是apache也是php。像搭建http服务器这种功能,本来是apache已经封装好的,但nodejs需要我们手动来搭建。其实在实际应用中,我们可以使用现成的框架。但这里,我想手动搭建,也加深一下对http服务器的理解。
我们node执行下面这个文件,我命名为http.js,它将创建一个httpServer并监听3000端口。
var PORT = 3000;
var http = require('http');
var url=require('url');
var fs=require('fs');
var mine=require('./mine').types;
var path=require('path');
var server = http.createServer(function (request, response) {
var pathname = url.parse(request.url).pathname;
var realPath = path.join("assets", pathname);
//console.log(realPath);
var ext = path.extname(realPath);
ext = ext ? ext.slice(1) : 'unknown';
fs.exists(realPath, function (exists) {
if (!exists) {
response.writeHead(404, {
'Content-Type': 'text/plain'
});
response.write("This request URL " + pathname + " was not found on this server.");
response.end();
} else {
fs.readFile(realPath, "binary", function (err, file) {
if (err) {
response.writeHead(500, {
'Content-Type': 'text/plain'
});
response.end(err);
} else {
var contentType = mine[ext] || "text/plain";
response.writeHead(200, {
'Content-Type': contentType
});
response.write(file, "binary");
response.end();
}
});
}
});
});
server.listen(PORT);
console.log("Server runing at port: " + PORT + ".");
上面我们还引入了一个mine.js,这是我自己写的,里面存储的是名值对,用于定义不同后缀的文件所对应的返回方式:
exports.types = {
"css": "text/css",
"gif": "image/gif",
"html": "text/html",
"ico": "image/x-icon",
"jpeg": "image/jpeg",
"jpg": "image/jpeg",
"js": "text/javascript",
"json": "application/json",
"pdf": "application/pdf",
"png": "image/png",
"svg": "image/svg+xml",
"swf": "application/x-shockwave-flash",
"tiff": "image/tiff",
"txt": "text/plain",
"wav": "audio/x-wav",
"wma": "audio/x-ms-wma",
"wmv": "video/x-ms-wmv",
"xml": "text/xml"
};
fs模块是用于读取文件的,提供读取文件的方法,其实仔细研究文档会发现,它有同步和异步两种读取方式。fs.exists这个方法网上很多文章写作path.exists,,现在推荐写作fs.exists这个方法。否则会报警:
需要注意的是,不仅浏览器访问html文件会形成一次访问,里面链接的js,css等外部文件也会分别形成一次http访问。所以,http.createServer的回调其实是在一次页面访问中执行了多次的。我们console.log(realPath)一下就可以看到:
这里并没有加入默认访问index.html的功能,所以访问地址要写全http://127.0.0.1:3000/index.html
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# nodejs搭建http服务器
# 搭建本地http服务器
# nodejs搭建本地服务器
# 基于Node.js的http模块搭建HTTP服务器
# NodeJS搭建HTTP服务器的实现步骤
# 利用node.js本地搭建HTTP服务器
# 搭建简单的nodejs http服务器详解
# 从零学习node.js之搭建http服务器(二)
# 使用nodejs搭建一个简易HTTP服务的实现示例
# 的是
# 我想
# 是在
# 也会
# 两种
# 这是我
# 不做
# 可以使用
# 上说
# 它将
# 命名为
# 则会
# 创建一个
# 需要注意
# 回调
# 大家多多
# 要写
# 装好
# 就可以
# 后端
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
浅谈javascript alert和confirm的美化
Laravel如何实现API速率限制?(Rate Limiting教程)
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
Laravel如何使用Service Container和依赖注入?(代码示例)
如何挑选最适合建站的高性能VPS主机?
EditPlus 正则表达式 实战(3)
Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】
Android利用动画实现背景逐渐变暗
详解Android中Activity的四大启动模式实验简述
详解Android——蓝牙技术 带你实现终端间数据传输
Laravel如何使用Blade模板引擎?(完整语法和示例)
如何用PHP快速搭建高效网站?分步指南
实例解析angularjs的filter过滤器
jQuery中的100个技巧汇总
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
jQuery 常见小例汇总
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
Laravel怎么发送邮件_Laravel Mail类SMTP配置教程
Swift中循环语句中的转移语句 break 和 continue
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
米侠浏览器网页背景异常怎么办 米侠显示修复
SQL查询语句优化的实用方法总结
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
JavaScript如何实现音频处理_Web Audio API如何工作?
如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】
中山网站制作网页,中山新生登记系统登记流程?
如何快速搭建FTP站点实现文件共享?
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
node.js报错:Cannot find module 'ejs'的解决办法
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
Python文本处理实践_日志清洗解析【指导】
Linux安全能力提升路径_长期防护思维说明【指导】
JavaScript实现Fly Bird小游戏
如何将凡科建站内容保存为本地文件?
微信小程序 闭包写法详细介绍
C++时间戳转换成日期时间的步骤和示例代码
HTML 中如何正确使用模板变量为元素的 name 属性赋值
如何注册花生壳免费域名并搭建个人网站?
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
Python3.6正式版新特性预览
Python文件流缓冲机制_IO性能解析【教程】
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
在centOS 7安装mysql 5.7的详细教程
三星网站视频制作教程下载,三星w23网页如何全屏?
如何快速辨别茅台真假?关键步骤解析
如何在建站宝盒中设置产品搜索功能?
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
利用JavaScript实现拖拽改变元素大小

