Как мне попасть в серверную часть Express с интерфейса ReactJS?

#reactjs #express #heroku

#reactjs #экспресс #heroku

Вопрос:

Я развернул свое приложение react express на heroku, и, похоже, я не могу попасть в API входа, обслуживаемый в server.js .

это интерфейс, в котором он работает локально и даже работал пару коммитов назад, но внезапно остановился…

           <a href="/login">
            <Button className="app-button" variant="success" size="lg" style={{marginTop:10, color: 'black'}}>
              Log In
            </Button>{' '}
          </a>          
  

package.json:

 {
  "name": "spotifyproj",
  "version": "0.1.0",
  "private": true,
  "homepage": " https://whispering-caverns-57172.herokuapp.com/",
  "dependencies": {
    "@testing-library/jest-dom": "^4.2.4",
    "@testing-library/react": "^9.5.0",
    "@testing-library/user-event": "^7.2.1",
    "bootstrap": "^4.5.2",
    "compression": "^1.7.4",
    "cookie-parser": "^1.4.5",
    "cors": "^2.8.5",
    "dotenv": "^8.2.0",
    "express": "^4.17.1",
    "morgan": "^1.10.0",
    "path": "^0.12.7",
    "querystring": "^0.2.0",
    "react": "^16.13.1",
    "react-bootstrap": "^1.3.0",
    "react-dom": "^16.13.1",
    "react-router-dom": "^5.2.0",
    "react-scripts": "3.4.3",
    "react-spotify-player": "^1.0.4",
    "spotify-web-api-js": "^1.5.0"
  },
  "scripts": {
    "start": "node server.js",
    "dev": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject",
    "heroku-postbuild": "npm install amp;amp; npm run build"
  },
  "eslintConfig": {
    "extends": "react-app"
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  }
}

  

использование fetch / axios для попытки попасть в нее также не сработало

Ответ №1:

У React есть маршрутизация на стороне клиента, так что a тег ничего не будет делать.

Вам нужна библиотека, подобная fetch или axios, чтобы запустить команду post to /login , указывающую на URL, по которому запущен сервер Express.

 import axios from 'axios';

const login = async () => {
  const response = await axios.post('http://localhost/login');

  // do something with response
}

return {
  <Button onClick={() => login()}>
    Log In
  </Button>
}