Question Serveur de fichiers rapide Node.js (fichiers statiques sur HTTP)


Existe-t-il un outil prêt à l'emploi Node.js (installé avec npm), cela m'aiderait à exposer le contenu du dossier en tant que serveur de fichiers sur HTTP.

Exemple, si j'ai

D:\Folder\file.zip
D:\Folder\file2.html
D:\Folder\folder\file-in-folder.jpg

Puis à partir de D:\Folder\  node node-file-server.js Je pouvais accéder au fichier via

http://hostname/file.zip
http://hostname/file2.html
http://hostname/folder/file-in-folder.jpg

Pourquoi le serveur de fichiers statiques de mon nœud supprime-t-il les demandes? référence un peu mystique

serveur de fichiers statique standard node.js

S'il n'y a pas un tel outil, quel cadre devrais-je utiliser?

En relation: Serveur de fichiers statique de base dans NodeJS


444
2018-05-02 08:45


origine


Réponses:


Un bon outil "prêt à l'emploi" pourrait être http-server:

npm install http-server -g

Pour l'utiliser:

cd D:\Folder
http-server

Ou, comme ceci:

http-server D:\Folder

Vérifiez-le: https://github.com/nodeapps/http-server


780
2018-05-03 02:48



Si vous ne voulez pas utiliser l'outil prêt, vous pouvez utiliser le code ci-dessous, comme démontré par moi à https://developer.mozilla.org/en-US/docs/Node_server_without_framework:

var http = require('http');
var fs = require('fs');
var path = require('path');

http.createServer(function (request, response) {
    console.log('request starting...');

    var filePath = '.' + request.url;
    if (filePath == './')
        filePath = './index.html';

    var extname = path.extname(filePath);
    var contentType = 'text/html';
    switch (extname) {
        case '.js':
            contentType = 'text/javascript';
            break;
        case '.css':
            contentType = 'text/css';
            break;
        case '.json':
            contentType = 'application/json';
            break;
        case '.png':
            contentType = 'image/png';
            break;      
        case '.jpg':
            contentType = 'image/jpg';
            break;
        case '.wav':
            contentType = 'audio/wav';
            break;
    }

    fs.readFile(filePath, function(error, content) {
        if (error) {
            if(error.code == 'ENOENT'){
                fs.readFile('./404.html', function(error, content) {
                    response.writeHead(200, { 'Content-Type': contentType });
                    response.end(content, 'utf-8');
                });
            }
            else {
                response.writeHead(500);
                response.end('Sorry, check with the site admin for error: '+error.code+' ..\n');
                response.end(); 
            }
        }
        else {
            response.writeHead(200, { 'Content-Type': contentType });
            response.end(content, 'utf-8');
        }
    });

}).listen(8125);
console.log('Server running at http://127.0.0.1:8125/');

METTRE À JOUR Si vous avez besoin d'accéder à votre serveur à partir d'une demande / d'un fichier externe, vous devez surmonter le CORS, dans votre fichier node.js en écrivant ce qui suit, comme je l'ai mentionné dans une réponse précédente ici

// Website you wish to allow to connect
response.setHeader('Access-Control-Allow-Origin', '*');

// Request methods you wish to allow
response.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');

// Request headers you wish to allow
response.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');

// Set to true if you need the website to include cookies in the requests sent
// to the API (e.g. in case you use sessions)
response.setHeader('Access-Control-Allow-Credentials', true);

METTRE À JOUR

Comme Adrian l’a mentionné, dans les commentaires, il a écrit un code ES6 avec des explications complètes. ici, Je viens de republier son code ci-dessous, au cas où le code serait parti du site d'origine pour une raison quelconque:

const http = require('http');
const url = require('url');
const fs = require('fs');
const path = require('path');
const port = process.argv[2] || 9000;

http.createServer(function (req, res) {
  console.log(`${req.method} ${req.url}`);

  // parse URL
  const parsedUrl = url.parse(req.url);
  // extract URL path
  let pathname = `.${parsedUrl.pathname}`;
  // based on the URL path, extract the file extention. e.g. .js, .doc, ...
  const ext = path.parse(pathname).ext;
  // maps file extention to MIME typere
  const map = {
    '.ico': 'image/x-icon',
    '.html': 'text/html',
    '.js': 'text/javascript',
    '.json': 'application/json',
    '.css': 'text/css',
    '.png': 'image/png',
    '.jpg': 'image/jpeg',
    '.wav': 'audio/wav',
    '.mp3': 'audio/mpeg',
    '.svg': 'image/svg+xml',
    '.pdf': 'application/pdf',
    '.doc': 'application/msword'
  };

  fs.exists(pathname, function (exist) {
    if(!exist) {
      // if the file is not found, return 404
      res.statusCode = 404;
      res.end(`File ${pathname} not found!`);
      return;
    }

    // if is a directory search for index file matching the extention
    if (fs.statSync(pathname).isDirectory()) pathname += '/index' + ext;

    // read file from file system
    fs.readFile(pathname, function(err, data){
      if(err){
        res.statusCode = 500;
        res.end(`Error getting the file: ${err}.`);
      } else {
        // if the file is found, set Content-type and send data
        res.setHeader('Content-type', map[ext] || 'text/plain' );
        res.end(data);
      }
    });
  });


}).listen(parseInt(port));

console.log(`Server listening on port ${port}`);

133
2018-03-14 08:12



Pour les personnes souhaitant un serveur exécutable depuis le script NodeJS:

Vous pouvez utiliser expressjs / serve-static qui remplace connect.static (qui n'est plus disponible depuis la connexion 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);

puis à partir de la ligne de commande:

  • $ npm install finalhandler serve-static
  • $ node myapp.js

64
2017-07-04 13:16



Je sais que ce n'est pas Node, mais j'ai utilisé SimpleHTTPServer de Python:

python -m SimpleHTTPServer [port]

Cela fonctionne bien et vient avec Python.


46
2018-05-02 14:49



relier pourrait être ce que vous recherchez.

Installé facilement avec:

npm install connect

Ensuite, le serveur de fichiers statique le plus basique pourrait être écrit comme:

var connect = require('connect'),
    directory = '/path/to/Folder';

connect()
    .use(connect.static(directory))
    .listen(80);

console.log('Listening on port 80.');

33
2018-05-02 08:52



Installez express en utilisant npm: https://expressjs.com/en/starter/installing.html

Créez un fichier nommé server.js au même niveau que votre index.html avec ce contenu:

var express = require('express');
var server = express();
server.use('/', express.static(__dirname + '/'));
server.listen(8080);

Si vous souhaitez le placer à un autre endroit, définissez le chemin sur la troisième ligne:

server.use('/', express.static(__dirname + '/public'));

CD dans le dossier contenant votre fichier et exécutez le noeud depuis la console avec cette commande:

node server.js

Parcourir localhost: 8080


12
2017-07-22 08:46



Il y a un autre serveur web statique qui est plutôt sympa: la synchronisation du navigateur.

Il peut être téléchargé en utilisant le gestionnaire de paquets de nœuds:

npm install -g browser-sync

Après l'installation, accédez au dossier du projet dans l'invite cmd et exécutez simplement ce qui suit:

browser-sync start --server --port 3001 --files="./*"

Il va commencer à traiter tous les fichiers dans le dossier actuel dans le navigateur.

Plus peut être trouvé de BrowserSync

Merci.


7
2018-01-12 02:37