node.js搭建web本地服务器

这篇博客介绍了如何利用Node.js创建一个简单的临时服务器,用于处理资源获取和基本业务。通过引入http, url, fs, path和自定义的mime类型模块,服务器能响应不同类型的文件请求,并设置相应的Content-Type和跨域策略。用户可以访问http://127.0.0.1:7171/资源路径来获取本地assets目录下的文件。

基于 node.js 搭建的临时服务器,可用于临时资源获取,简单业务处理

导包:

npm i http
npm i url
/** 读取文件 */
npm i fs
npm i path

自己定义的返回类型

/** 自定义类型 */
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",
  "zip": "application/zip",
  "xml": "text/xml"
};
var PORT = 7171; // 自定义端口

var http = require('http');
var url = require('url');
var fs = require('fs');
var path = require('path');
var mine = require('./mine').types;

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': "application/json;charset=utf-8"
            });
            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': "application/json;charset=utf-8"
                    });
                    response.end(err);
                } else {
                    var contentType = mine[ext] || "text/plain";
                    /** 配置跨域 */
                    response.writeHead(200, {
                        'Content-Type': contentType,
                        'Access-Control-Allow-Origin': '*',
                        "Access-Control-Request-Method": '*',
                        'Access-Control-Allow-Headers': '*'
                    });
                    response.write(file, "binary");
                    response.end();
                }
            });
        }
    });
});

console.log(server);
server.listen(PORT); // 运行 脚本、监听 post 端口
console.log("Server runing at port: " + PORT + ". lxyy"); // 成功输出日志

命令行执行 node index.js

运行成功截图
在这里插入图片描述

请求路径 http://127.0.0.1:7171/资源路径

ps : http://127.0.0.1:7171/cover/LXYY0671.jpg

文件目录

在这里插入图片描述

请求各种格式文件转文件流 相关链接

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值