Как сделать POST-запрос через API выборки с локальным клиентом и сервером? - PullRequest
0 голосов
/ 20 марта 2019

Я использую два отдельных сервера через webpack и express; сервер разработчика и клиентский сервер.

У меня есть кнопка на клиенте, и я хочу отправить POST-запрос на сервер при нажатии кнопки. Я создаю запрос, используя пример из https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch

const testButton = document.querySelector(`button.test`);

const sendRequest = event => {
    event.preventDefault(); //stop or prevents the browser from executing the default action

    postData(`http://localhost:8080/`, { answer: 42 }) // line:32
        .then(data => console.log(JSON.stringify(data))) // JSON-string from `response.json()` call , line:33
        .catch(error => console.error(error));

    function postData(url = ``, data = {}) {
        // Default options are marked with *
        return fetch(url, { // line:38
            method: 'POST', // *GET, POST, PUT, DELETE, etc.
            mode: 'no-cors', // no-cors, cors, *same-origin
            cache: 'no-cache', // *default, no-cache, reload, force-cache, only-if-cached
            credentials: 'same-origin', // include, *same-origin, omit
            headers: {
                'Content-Type': 'application/json',
                // "Content-Type": "application/x-www-form-urlencoded",
            },
            redirect: 'follow', // manual, *follow, error
            referrer: 'no-referrer', // no-referrer, *client
            body: JSON.stringify(data), // body data type must match "Content-Type" header
        });
        // .then(response => response.json()); // parses JSON response into native Javascript objects
    }

    console.log(`sends POST request from here`);
};
testButton.addEventListener(`click`, sendRequest);

Когда я нажимаю на кнопку, я получаю эту ошибку:

sends POST request from here // console.log message in request
POST http://localhost:8080/ 404 (Not Found)
postData @ index.js:38
sendRequest @ index.js:32
index.js:33 {}

скриптов в package.json

    "scripts": {
        "start": "webpack",
        "dev-server": "nodemon bin/dev localhost 8080",
        "dev-client": "webpack-dev-server --port 3000"
    }

devServer в webpack.config.js


    devServer: {
        historyApiFallback: true,
        hot: true,
        inline: true,

        host: 'localhost',
        port: 3000,
         proxy: {
          '/api/': 'http://localhost:8080',
          }
    },

Я пробовал это для прокси

proxy: {
          '^/api/*': {
            target: 'http://localhost:8080/api/',
            secure: false
          }
        }

1 Ответ

0 голосов
/ 20 марта 2019
  1. Вы запустили свой экспресс-сервер?
  2. Есть ли в вашем экспресс-приложении пустое сопоставление конечных точек (это также должно быть сопоставление POST)?
  3. А если вы используете докер (для экспресс), он прослушивает ваш внутренний порт?

Ваш код запроса на первый взгляд выглядит отлично.

...