首页 > 编程语言 >建简单的静态文件服务器:使用Node.js和HTTP模块

建简单的静态文件服务器:使用Node.js和HTTP模块

时间:2023-11-15 11:44:06浏览次数:37  
标签:Node 文件 const filePath res js 服务器 HTTP

创建简单的静态文件服务器:使用Node.js和HTTP模块

在Web开发中,经常需要搭建一个能够提供静态文件访问的服务器。无论是用于本地开发调试,还是用于部署网站,这都是一个常见的需求。本篇文章将介绍如何使用Node.js和其内置的HTTP模块来创建一个简单的静态文件服务器。

准备工作

首先,确保你已经安装了Node.js环境。如果没有安装,可以到Node.js官网(nodejs.org/)下载并安装最新版本。

代码实现

接下来,我们将通过以下代码来创建一个简单的静态文件服务器:

javascript

复制代码

const http = require('http'); const fs = require('fs'); const path = require('path'); const server = http.createServer((req, res) => { // 省略上面提到的代码,详见下文 }); const port = process.env.PORT || '3030'; server.listen(port, () => { console.log(`Server running at http://localhost:${port}/`); });

代码解释:我们首先导入了Node.js内置的httpfspath模块,分别用于创建HTTP服务器、读取文件和处理文件路径。然后使用http.createServer方法创建了一个HTTP服务器,并传入了一个回调函数处理请求和响应。接着定义了服务器监听的端口号,并通过server.listen方法来启动服务器。

接下来,我们需要完善回调函数中的逻辑,使其能够根据请求的路径返回相应的静态文件内容。以下是完整的代码:

javascript

复制代码

// 上面提到的回调函数 const server = http.createServer((req, res) => { let filePath = '.' + req.url; if (filePath === './') { filePath = './index.html'; } // 省略文件类型判断和读取文件的部分,详见下文 }); // 省略端口设置和服务器启动的部分

在上面的代码中,我们根据请求的URL构造了文件路径filePath,并设置了默认的文件路径为'./index.html'。接下来,我们需要根据文件的扩展名来确定其Content-Type,并读取文件内容,然后将文件内容作为响应返回给客户端。具体的文件类型判断和读取文件的部分如下:

javascript

复制代码

// 文件类型判断和读取文件的部分 const extname = String(path.extname(filePath)).toLowerCase(); const contentType = { '.html': 'text/html', '.js': 'text/javascript', // ... 其他文件类型的Content-Type }[extname] || 'application/octet-stream'; fs.readFile(filePath, function (error, content) { if (error) { if (error.code === 'ENOENT') { // 文件不存在 fs.readFile('./404.html', function (error, content) { res.writeHead(404, {'Content-Type': 'text/html'}); res.end(content, 'utf-8'); }); } else { // 其他错误 res.writeHead(500); res.end('Sorry, check with the site admin for error: ' + error.code + ' ..\n'); res.end(); } } else { // 文件存在 res.writeHead(200, {'Content-Type': contentType}); res.end(content, 'utf-8'); } });

在上面的代码中,我们首先通过path.extname方法获取文件的扩展名,然后根据扩展名确定其Content-Type,并使用fs.readFile方法读取文件内容。如果读取文件出现错误,我们会返回相应的状态码和错误信息;如果文件存在,则根据Content-Type设置响应头,并将文件内容返回给客户端。

运行服务器

保存以上代码到一个文件(比如server.js),然后打开命令行,进入文件所在目录,运行以下命令启动服务器:

bash

复制代码

node server.js

此时,服务器会在默认端口3030上启动,你可以打开浏览器访问http://localhost:3030/来查看效果。如果需要修改端口,可以通过设置环境变量PORT来改变监听的端口号,比如:

bash

复制代码

PORT=8080 node server.js

总结

通过本篇文章,我们学习了如何使用Node.js和HTTP模块来创建一个简单的静态文件服务器。这个服务器可以用于提供HTML、CSS、JavaScript等静态文件,在开发调试和部署网站时非常有用。希望这篇文章能够帮助你更好地理解Node.js的HTTP模块以及静态文件服务器的实现原理。

完整代码

javascript

复制代码

const http = require('http'); // 导入内置的 http 模块 const fs = require('fs'); // 导入内置的文件系统模块 const path = require('path'); // 导入内置的路径处理模块 const server = http.createServer((req, res) => { let filePath = '.' + req.url; // 构造文件路径,以当前目录为根目录 if (filePath === './') { // 如果文件路径为根路径 filePath = './index.html'; // 默认返回 index.html 文件 } const extname = String(path.extname(filePath)).toLowerCase(); // 获取文件的扩展名并转换为小写 const contentType = { // 定义不同文件类型对应的 Content-Type '.html': 'text/html', '.js': 'text/javascript', '.css': 'text/css', '.json': 'application/json', '.png': 'image/png', '.jpg': 'image/jpg', '.gif': 'image/gif', '.svg': 'image/svg+xml', '.wav': 'audio/wav', '.mp4': 'video/mp4', '.woff': 'application/font-woff', '.ttf': 'application/font-ttf', '.eot': 'application/vnd.ms-fontobject', '.otf': 'application/font-otf', '.wasm': 'application/wasm' }[extname] || 'application/octet-stream'; // 如果找不到对应的 Content-Type,默认使用 application/octet-stream fs.readFile(filePath, function (error, content) { // 读取文件内容的回调函数 if (error) { // 如果读取文件出现错误 if (error.code === 'ENOENT') { // 如果文件不存在 fs.readFile('./404.html', function (error, content) { // 读取 404.html 文件 res.writeHead(404, {'Content-Type': 'text/html'}); // 返回状态码和 Content-Type res.end(content, 'utf-8'); // 返回文件内容 }); } else { // 其他错误 res.writeHead(500); // 返回状态码 500 res.end('Sorry, check with the site admin for error: ' + error.code + ' ..\n'); // 返回错误信息 res.end(); // 结束响应 } } else { // 如果文件存在 res.writeHead(200, {'Content-Type': contentType}); // 返回状态码和对应的 Content-Type res.end(content, 'utf-8'); // 返回文件内容 } }); }); const port = process.env.PORT || '3030'; // 设置服务器监听的端口号,默认为 3030 server.listen(port, () => { console.log(`Server running at http://localhost:${port}/`); // 在控制台输出服务器启动信息 });

注意

运行server.js文件,需要把文件放的build目录里面。如果想要放到build目录外面则要更改 这里build的目录设置

js

复制代码

let filePath = './build' + req.url; if (filePath === './build/') { filePath = './build/index.html'; }

本文转自 https://juejin.cn/post/7300287280745005066,如有侵权,请联系删除。

本文由mdnice多平台发布

标签:Node,文件,const,filePath,res,js,服务器,HTTP
From: https://www.cnblogs.com/frontendBoyWang/p/17833475.html

相关文章

  • frps: 2023/11/15 10:49:24 http: Accept error: accept tcp [::]:7650: accept4: too
    0.错误信息表明frps服务在接受传入连接时遇到了问题,特别是与端口7750相关的错误,具体错误为"accepttcp[::]:7750:accept4:toomanyopenfiles",意味着打开文件数目过多。这种错误通常发生在系统达到文件描述符的打开数目限制时。在类Unix操作系统中,每个进程都有同时可以......
  • c# 直接读取 json 数据
    usingNewtonsoft.Json.Linq;usingSystem;usingSystem.IO;classProgram{staticvoidMain(){stringjson=File.ReadAllText("data.json");//从文件中读取JSON数据JObjectjsonObject=JObject.Parse(json);//解析JSON数据stringn......
  • vuejs3.0 从入门到精通——项目搭建
    项目搭建一、环境准备软件名称软件版本nodev20.9.0npm10.1.0Windows10专业版22H2vue/cli5.0.8vitev4.5.0二、vite创建项目>npminitvite@latestsaas--templatevue√Selectaframework:»Vue√Selectavariant:»TypeScriptSca......
  • requests 2.13.0 版本的 https 连接慢漏提示
    解决方案requests2.13.0版本的https连接慢漏问题问题背景:在使用requests2.13.0版本时,发现存在一个缓慢的泄漏问题。这个问题只在使用https连接时出现。经过调查,发现这个问题与pyOpenSSL的使用有关。在使用pyOpenSSL与requests2.13.0版本时,存在一个泄漏问题,而在移除pyOpenSSL......
  • JS前端验证
    验证上传文件的是否符合要求既可以通过前端js代码验证,也可以通过后端PHP代码验证他们的区别如下:前端的任何代码都可以被检查网页源代码检测出来后端的任何代码在没有拿到源码之前都无法被识别出来通过禁用JS代码可以绕过js的前端验证判断前端验证是否为JS代码:1.直接查看网页......
  • Hive_解析 get_json_object
    get_json_object(stringjson_string,stringpath)说明: 第一个参数填写json对象变量,第二个参数使用$表示json变量标识,然后用.或[]读取对象或数组。如果输入的json字符串无效,那么返回NULL。 每次只能返回一个数据项。举例: data为test表中的字段,数据结构如下:......
  • net/http 01
    用net/http包可以快速起一个web服务点击查看代码packagemainimport("fmt""net/http")funchelloWorld(whttp.ResponseWriter,req*http.Request){_,err:=fmt.Fprintf(w,"Helloworld!")iferr!=nil{fmt.Pr......
  • 创建自己的https证书(转)
    使用mkcert工具创建证书1、下载mkcert工具,下载地址如下:​​ ​mkcert工具下载​​百度下载:链接:​ ​https://pan.baidu.com/s/10ym5W91g612LDk3t9isFGQ ​​提取码:12342、解压后运行https本地证书生成工具.bat(文件上点鼠标右键,以管理员身份运行) 生成的证书在C:\Users\cx......
  • XMLHttpRequest 使用方法:var xhr=new XMLHttpRequest();xhr.open('get','xxxx',true)
    Ajax技术核心就是XMLHttpRequest对象。Ajax技术的工作原理:可以分成3步1.创建Ajax对象:varxhr=newXMLHttpRequest();2.xhr发送请求:xhr.open('get','test.html','true');xhr.send();3.xhr获取响应:xhr.onreadystatechange=function(){if(xhr.readys......
  • js处理前端页面复选框多页复选同时生效的问题
    虽然是后端开发,但在实际的工作中难免会碰到一些前端相关的任务需要自己处理,下面就是本人开发工作中处理的前端相关分页复选的问题。总结一下,以备日后重复遇到:<scripttype="text/javascript">//初始化数据$(function(){$('#queryButton').removeAttr('disabled'......