Почему я не могу отреагировать на взаимодействие с моим экспресс-бэкэндом? - PullRequest
0 голосов
/ 25 февраля 2019

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

Я одновременно запускаю и интерфейс, и сервер, но в моем интерфейсе я получаю ошибку App.js:78 GET http://localhost:3000/express_backend 404 (Not Found)

Почему он все еще пытается прочитать изпорт 3000?Мой экспресс-сервер работает через порт 5000, я думал, что прокси-линия в моем package.json позаботится об этом, но, похоже, он не работает.

Моя структура каталогов выглядит следующим образом:

├── src
|   └── index.js (express server)
|   └── package.json
|   ├── client
|       └── App.js (react component)

Любой совет, как это исправить?

Компонент My React:

class App extends Component {

  constructor(props) {
    super(props);
    this.state = {
      data: null
    };
  }

  componentDidMount() {
    this.callBackendAPI()
      .then(res => this.setState({ data: res.express }))
      .catch(err => console.log(err));
  }

  async callBackendAPI() {
    const response = await fetch('/express_backend');
    const body = await response.json();

    if(response.status !== 200) {
      throw Error(body.message)
    }
    return body;
  }

  render() {
    return (
      <div className="App">
        <header className="App-header">
          <h1 className="App-title">Welcome to React</h1>
        </header>
        // Render the newly fetched data inside of this.state.data 
        <p className="App-intro">{this.state.data}</p>
      </div>
    );
  }
}

export default (App);

Бэкэнд My Express:

const express = require('express');
const path = require('path');

const app = express();

// serve the static files from the React App
app.use(express.static(path.join(__dirname, 'client/build')));

// an api endpoint that returns a short list of items
app.get('/api/getList', (req, res) => {
  var list = ["item1", "item2", "item3"];
  res.json(list);
  console.log('Sent list of items');
});

app.get('/express_backend', (req, res) => {
  res.send({ express: 'Express backend is connected to react' });
});

// handles any requests that don't match the ones above
app.get('*', (req, res) => {
  res.sendFile(path.join(__dirname + '/client/build/index.html'));
});

const port = process.env.PORT || 5000;
app.listen(port);

console.log('App is listening on port ' + port);

Package.json сзапись прокси:

{
  "name": "contacts-application",
  "version": "0.0.1",
  "description": "A simple Contacts application written using the MERN stack (Mongo, Express, React, Node) and Redux",
  "main": "app.js",
  "license": "MIT",
  "private": true,
  "dependencies": {
    "@babel/polyfill": "^7.2.5",
    "express": "^4.16.4",
    "react": "16.5.2",
    "react-dom": "16.5.2"
  },
  "scripts": {
    "dev": "webpack-dev-server --mode development",
    "start": "node src/index.js"
  },
  "proxy": "http://localhost:5000/",
  "devDependencies": {
    "@babel/cli": "7.1.0",
    "@babel/core": "7.1.0",
    "@babel/preset-env": "7.1.0",
    "@babel/preset-react": "7.0.0",
    "babel-loader": "8.0.2",
    "css-loader": "1.0.0",
    "react-hot-loader": "4.3.11",
    "style-loader": "0.23.0",
    "webpack": "4.19.1",
    "webpack-cli": "3.1.1",
    "webpack-dev-server": "3.1.8"
  }
}
...