Угловой 6 |Экспресс: Ошибка 404 для файлов dist - PullRequest
0 голосов
/ 23 мая 2018

Спасибо, что нашли время, чтобы прочитать мой вопрос.Мой сайт работает нормально, когда я запускаю ng serve.Когда я запускаю ng build --prod, это тоже хорошо работает.Проблема в том, когда я пытаюсь сделать index.html в дистрибутиве, получая 404 ошибки.Ошибки - 404 ошибки для моих основных, стилей и файлов polyfill.Я пытаюсь создать серверную часть, чтобы я мог обрабатывать платежи по карте.Буду признателен за любую помощь - уже несколько часов без решимости стучу головой о стену.Это мой код ниже:

server.js

var express = require('express');
var app = express();
var server = require('http').Server(app);
var bodyParser = require('body-parser');

app.use(express.static(__dirname));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));

server.listen(2000, function(){
    console.log('Listening on 2000..')
});
console.log(__dirname);


app.get('/', (req, res) => {
    res.sendFile(__dirname + '/dist/culture/index.html');
});

src / index.html

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Culture</title>
  <base href="/">

  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link rel="icon" type="image/x-icon" href="favicon.ico">
  <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css" integrity="sha384-WskhaSGFgHYWDcbwN70/dfYBj47jz9qbsMId/iRN3ewGhXQFZCSftd1LZCfmhktB" 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.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script>
  <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.0.13/css/all.css" integrity="sha384-DNOHZ68U8hZfKXOrtjWvjxusGo9WQnrNx2sqG0tfsghAvtVlRW3tvkXWZh58N9jp" crossorigin="anonymous">
  <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
</head>
<body>
  <app-root></app-root>

</body>
</html>

dist / index.html

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Culture</title>
  <base href="/">

  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link rel="icon" type="image/x-icon" href="favicon.ico">
  <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css" integrity="sha384-WskhaSGFgHYWDcbwN70/dfYBj47jz9qbsMId/iRN3ewGhXQFZCSftd1LZCfmhktB" 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.1/js/bootstrap.min.js" integrity="sha384-smHYKdLADwkXOn1EmN1qk/HfnUcbVRZyYmZ4qpPea6sjB/pTJ0euyQp0Mk8ck+5T" crossorigin="anonymous"></script>
  <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.0.13/css/all.css" integrity="sha384-DNOHZ68U8hZfKXOrtjWvjxusGo9WQnrNx2sqG0tfsghAvtVlRW3tvkXWZh58N9jp" crossorigin="anonymous">
  <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
<link rel="stylesheet" href="styles.aaf8a2468e47be90b64b.css"></head>
<body>
  <app-root></app-root>

<script type="text/javascript" src="runtime.a66f828dca56eeb90e02.js"></script><script type="text/javascript" src="polyfills.b4daf421c94934f530d4.js"></script><script type="text/javascript" src="main.36d7357da7cc32c08c65.js"></script></body>
</html>

Опять же, вкратце, localhost выдает 200 кодов, и это хорошо, это означает, что он соединяется с нужным местом.Проблема в том, что после подключения он не может найти какие-либо файлы.Что я делаю неправильно?Спасибо

1 Ответ

0 голосов
/ 23 мая 2018

Вы должны исправить эту строку кода: app.use(express.static(__dirname)); примерно так: app.use(express.static(path.join(__dirname, 'dist/culture')));, если файлы приложения Angular находятся в каталоге dist/culture.

Основная проблема заключается в том, что когда ваш index.html дляпример пытается загрузить <link rel="icon" type="image/x-icon" href="favicon.ico">, он использует запрос к пути http://localhost:2000/favicon.ico.Ваш express бэкэнд определил статические активы в __dirname, а ваше фактическое приложение в dist/culture, поэтому ваш запрос должен выглядеть следующим образом: http://localhost:2000/dist/culture/favicon.ico.

В результате внесенных изменений улучшена конфигурация расположения статических файлов.

...