узел express.static для чтения всего каталога - PullRequest
0 голосов
/ 29 ноября 2018

Я работаю над проектом видеопортала.Видео делятся на разные папки на сервере. Я использую технологию nodejs.Моя цель - это функция чтения папки, которая обслуживает весь видеоконтент в папке.В настоящее время приведенный ниже код служит конкретному файлу вместо папки.Я буду признателен за ваш вклад.спасибо

  let express = require('express');
let bodyParser = require('body-parser');
let path = require('path');

let fs = require('fs');
var ejs=require('ejs');
let port = process.env.PORT || 4000;
let videosPath = './videos/';



let app = express();

/*let logger = function(req, res, next){
    console.log("logging...");
}
app.use(logger);*/

//view engine
app.set('view engine', 'ejs');
app.set('views', path.join( __dirname, 'views'));

//routing alternative
//app.use(express.static('public'));


// using body parser
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: false}));



app.get('/videos/:id',function(req,res){

    fs.readdir(`./videos/${req.params.id}`, (err, files) => {
       console.log(files);
       res.render('pages/index',{videos:files,cateogry_id:req.params.id});
    });

});

app.get('/',function(req,res){
res.render('index');});


app.listen(port, function(){
    console.log("server runnung on 4000");
});

1 Ответ

0 голосов
/ 29 ноября 2018

использовать EJS для рендеринга шаблона:

см. Эту ссылку для учебника,

создать папку представлений внутри корнякаталог вашего проекта, внутри которого мы создаем наши ejs-страницы для рендера

теперь создаем index.ejs файл внутри имя_проекта / views /

внутри вашего index.ejs файла

<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>
</head>
<body>

  <h3><%=videos.length+'total videos'%><h3>

  <div class="row">

  <% videos.forEach(function(video)){ %>
       <div class="col-lg-4 my-2">
         <video width="320" height="240" autoplay>
            <source src="<%= '/videos/'+category_id+'/'+video%>" type="video/mp4">
         </video>
       </div>
  <%})%>
  </div>


</body>
</html>

использовать модуль fs

мы будем использовать fs чтение содержимого папки видео

внутри вашей папки видео,создайте папки по category_id, внутри которых разместите ваши видео

как videos/1/myvideo.mp4

и добавьте это в ваш app.js файл

var fs = require('fs');
var ejs=require('ejs');

 // set the view engine to ejs
 app.set('view engine', 'ejs');


app.get('/category/:id',function(req,res){

    fs.readdir(`./videos/${req.params.id}`, (err, files) => {
       console.log(files);
       res.render('pages/index',{videos:files,cateogry_id:req.params.id});
    });

});
...