Невозможно опубликовать расчет на сервере - PullRequest
0 голосов
/ 04 февраля 2020

Проблема появляется, когда я нажимаю кнопку подтверждения. Ошибка 404 не найдена и на веб-сайте не удается выполнить POST / Index. У меня есть логические проблемы в коде или проблемы, которые возникают в синтаксисе. Моя программа работает без http-запроса, это просто обычный механизм импорта express и интеграция с html, который я пытаюсь выполнить базовую c функцию обратной отправки на express (сервер) и опубликовать ответ обратно к моему angular html.

Я пытаюсь отправить число обратно на сервер для расчета и не знаю, где ошибка, из-за которой я не смог сделать Post Функция. Пожалуйста, получите файл требований от меня, если загруженный мной файл не завершен.

app.component. html В моем HTML файле мне нужно что-то добавить для ссылки на server.ts? Есть ли еще какие-либо проблемы, которые мне нужно проверить?

    <!doctype html>
<html lang="en">
<head>
  <Title>Calculator</Title>
  <meta charset="utf-8">
  <title>Myapp</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://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" />

</head>
<body>


  <h1 align="center">Angular Calculator</h1>
  <div class="container">
    <div class="card">
      <div class="card-body">

        <form action="index" method="POST">
        <input type="number" name="num1" class="form-control" placeholder="Number">
        <input type="number" name="num2" class="form-control" placeholder="Number">
        <select ng-model="operator" name="operator">
          <option>+</option>
          <option>*</option>
          <option>-</option>
          <option>/</option>
          </select>
        <button type="submit">Submit</button>
      </form>
      <p>Calculation Of the number is :{{ result }} </p>

      </div>
  </div>
  </div>

</body>
</html>

server.ts file Это файл сервера по умолчанию, который генерирует npm, и я не уверен в синтаксисе кода какие-либо проблемы для моего первого тестирования функций сложения.

    import 'zone.js/dist/zone-node';
import 'reflect-metadata';
import * as bodyParser from 'body-parser';

import * as express from 'express';
import {join} from 'path';

// Express server
const app = express();

const PORT = process.env.PORT || 4000;
const DIST_FOLDER = join(process.cwd(), 'dist/browser');

// * NOTE :: leave this as require() since this file is built Dynamically from webpack
const {AppServerModuleNgFactory, LAZY_MODULE_MAP, ngExpressEngine, provideModuleMap} = require('./dist/server/main');

// Our Universal express-engine (found @ https://github.com/angular/universal/tree/master/modules/express-engine)
app.engine('html', ngExpressEngine({
  bootstrap: AppServerModuleNgFactory,
  providers: [
    provideModuleMap(LAZY_MODULE_MAP)
  ]
}));

app.set('view engine', 'html');
app.set('views', DIST_FOLDER);


app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
// Example Express Rest API endpoints
// app.get('/api/**', (req, res) => { });
// Serve static files from /browser
app.get('*.*', express.static(DIST_FOLDER, {
  maxAge: '1y'
}));

// All regular routes use the Universal engine
app.get('*', (req, res) => {
  res.render('/app.component.html', { req });
});
app.get('*', (req, res) => {
  res.status(404).send('data requests are not supported');
});

//have body-parser is a piece of express middleware that reads a form's 
//input and stores it as a javascript object accessible through
//can not to include body-parser but not to get the raw request, your body and header are not in the root object of request parameter
app.post('/',(req, res) => {
    //var num1 = req.body.operator
    var result=req.body;
    console.log(req.body);
    var operator = req.body.operator
        if (operator == "+")
        {
            res.render('/app.component.html', {
                result: parseInt(req.body.num1) + parseInt(req.body.num2),
            });
        } 



})
// Start up the Node server
app.listen(PORT, () => {
  console.log(`Node Express server listening on http://localhost:${PORT}`);
});

Ответы [ 3 ]

0 голосов
/ 04 февраля 2020

Я думаю, проблема в том, что вы не включили

'angular -route. js'

в коде на стороне клиента

0 голосов
/ 05 февраля 2020

Вы не можете публиковать в индексе <form action="index" method="POST">.

вам нужен файл на стороне сервера. как: <form action="form_process.php" method="POST">

0 голосов
/ 04 февраля 2020

Следующая строка подразумевает, что вы отправляете на /index:

<form action="index" method="POST">

Для отправки на службу express (которая размещена на порте 4000, и, следовательно, URL-адрес http://localhost : 4000 ), вы должны определить поведение отправки для вашей кнопки. Проверьте это для справки.

...