是否有Node.js即用工具(与npm一起安装),可以帮助我通过HTTP将文件夹内容作为文件服务器公开。
例如,如果我有
D:\Folder\file.zip
D:\Folder\file2.html
D:\Folder\folder\file-in-folder.jpg
然后从D:\Folder\node node-file-server.js开始我可以通过
http://hostname/file.zip
http://hostname/file2.html
http://hostname/folder/file-in-folder.jpg
为什么我的节点静态文件服务器丢弃请求?参考一些神秘的
标准node.js静态文件服务器
如果没有这样的工具,我应该使用什么框架?
相关:NodeJS中的基本静态文件服务器
对于希望在NodeJS脚本中运行服务器的用户:
您可以使用expressjs/serve-static替换connect.static(从connect 3起不再可用):
myapp.js:
var http = require('http');
var finalhandler = require('finalhandler');
var serveStatic = require('serve-static');
var serve = serveStatic("./");
var server = http.createServer(function(req, res) {
var done = finalhandler(req, res);
serve(req, res, done);
});
server.listen(8000);
然后从命令行:
$npm安装finalhandler服务静态$node myapp.js
使用npm安装express:https://expressjs.com/en/starter/installing.html
在index.html的同一级别创建一个名为server.js的文件,内容如下:
var express = require('express');
var server = express();
server.use(express.static(__dirname));
server.listen(8080);
这将加载index.html文件。如果希望指定要加载的html文件,请使用以下语法:
server.use('/', express.static(__dirname + '/myfile.html'));
如果要将其放置在其他位置,请在第三行设置路径:
server.use('/', express.static(__dirname + '/public'));
CD到包含文件的文件夹,然后使用以下命令从控制台运行节点:
node server.js
浏览到localhost:8080
我对这一页上的任何答案都没有太多的运气,然而,下面的答案似乎起了作用。
添加包含以下内容的server.js文件:
const express = require('express')
const path = require('path')
const port = process.env.PORT || 3000
const app = express()
// serve static assets normally
app.use(express.static(__dirname + '/dist'))
// handle every other route with index.html, which will contain
// a script tag to your application's JavaScript file(s).
app.get('*', function (request, response){
response.sendFile(path.resolve(__dirname, 'dist', 'index.html'))
})
app.listen(port)
console.log("server started on port " + port)
还要确保您需要快递。根据您的设置运行yarn add express-save或npm install express-save(我可以推荐yarn,它非常快)。
您可以将dist更改为您提供内容的任何文件夹。对于我的简单项目,我没有从任何文件夹提供服务,所以我只是删除了dist文件名。
然后可以运行node server.js。由于我必须将项目上传到Heroku服务器,我需要将以下内容添加到package.json文件中:
"scripts": {
"start": "node server.js"
}