@Praud

Как связать create-react-app с back-end сервером?

Всем привет, часа 3 сижу не могу связать реакт приложение с сервером на node (express)
В документации пишут прописать proxy в package.json.

"name": "marmelad",
  "version": "0.1.0",
  "private": true,
  "proxy": "http://localhost:3001/",


Так и сделал.

Вот мой ajax

import axios from 'axios';

export const userLoginRequest = (data) => dispatch => {
      // return axios.post('/api/auth', data);
      return fetch('/api/auth', {
            method: 'POST',
            headers: {
               'Content-Type': 'text/html' 
            },
            body: data
      })
}


Использовал axios, но уже с фетчем пытаюсь, так в документации.
Запросы все равно уходят на localhost:3000, вместо 3001.

На серверной части все прозрачно

import express from 'express';
import bodyParser from 'body-parser';
// import cors from 'cors';

// import users from './routes/users';
import auth from './routes/auth';

const app = express();

app.use(bodyParser.json());

app.use((req, res, next) => {
    res.header("Access-Control-Allow-Origin", "*");
    res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
    next();
})

app.set('port', (process.env.PORT || 3001));

// Express only serves static assets in production
if (process.env.NODE_ENV === 'production') {
  app.use(express.static('client/build'));
}

app.use('/api/auth', auth);

app.listen(app.get('port'), () => {
  console.log(`Find the server at: http://localhost:${app.get('port')}/`);
});


import express from 'express';

let router = express.Router();

router.post('/api/auth', (req, res) => {
    console.log(req.body);
})

export default router;
  • Вопрос задан
  • 2123 просмотра
Пригласить эксперта
Ответы на вопрос 2
fdhadzh
@fdhadzh
Perfectionist with deadlines
Видимо, `proxy` это настройка для npm. Вам необходимо использовать свою конфигурацию или читать из package.json и подставлять при запросе.
Ответ написан
Комментировать
@Praud Автор вопроса
app.use('/api/auth', auth);

Здесь просто
app.use('/', auth);

В этом была проблема
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы