API вызова хорошо работает через почтальона, но публикация через axios не работает - PullRequest
0 голосов
/ 10 мая 2018

Я делаю приложение для нативной реакции, Я зарегистрировал headlessJS, который делает вызов API. API отлично работает через почтальона, но при отправке запроса через приложение возникает ошибка Это мой код в приложении для запроса

axios({
  method: 'post',
  url: '13.126.71.152:3000/checkin',
  data: {
      location,
      name: naming
  }
}).then((res) => {
  return res;
}).then((resp) => {
  console.log(resp);
}).catch((error) => {
  console.log(error);
});

Я получаю следующую ошибку

Error: Network Error
at createError (20ecc2c2-cb5e-4e50-9…-5e92abf47ba8:80610)
at XMLHttpRequest.handleError (20ecc2c2-cb5e-4e50- 
9…-5e92abf47ba8:80518)
at XMLHttpRequest.dispatchEvent (20ecc2c2-cb5e-4e50-9…-5e92abf47ba8:17922)
at XMLHttpRequest.setReadyState (20ecc2c2-cb5e-4e50-9…-5e92abf47ba8:17677)
at XMLHttpRequest.__didCompleteResponse (20ecc2c2-cb5e-4e50-9…-5e92abf47ba8:17504)
at 20ecc2c2-cb5e-4e50-9…-5e92abf47ba8:17614
at RCTDeviceEventEmitter.emit (20ecc2c2-cb5e-4e50-9…f-5e92abf47ba8:3478)
at MessageQueue.__callFunction (20ecc2c2-cb5e-4e50-9…f-5e92abf47ba8:2384)
at 20ecc2c2-cb5e-4e50-9…f-5e92abf47ba8:2154
at MessageQueue.__guardSafe (20ecc2c2-cb5e-4e50-9…f-5e92abf47ba8:2346)

Код моего сервера на узле js Мой код server.js

    var express = require('express');
    app = express();
    const cors = require('cors');
    const path = require('path');
    port = process.env.PORT || 3000,
    bodyParser = require('body-parser');

    app.use(bodyParser.urlencoded({ extended: true }));
    app.use(bodyParser.json());
    // Set public folder
    app.use(express.static(path.join(__dirname, 'public')));
    app.use(function(req, res, next) {
       res.header("Access-Control-Allow-Origin", "*");
       res.header('Access-Control-Allow-Methods', 'DELETE, PUT');
       res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept,x-auth");
       res.header('Access-Control-Expose-Headers', 'x-auth');
       next();
    });

    var routes = require('./api/routes/MetroRoutes'); //importing 
route
    routes(app); //register the route

    app.listen(port);

    app.use(function(req, res) {
      res.status(404).send({url: req.originalUrl + ' not found'})
    });
    console.log('metro RESTful API server started on: ' + port);

Код моего контроллера: ./api/controllers/MetroController

    exports.checkInDetected = function(req,res) {
      console.log(req.body);
      pusher.trigger( 'ieacon-calc', 'checkInDetected', {
      "name": req.body.name,
      "location": req.body.location
      });
      res.json({ message: 'checkInDetected' });

    }

    exports.checkOutDetected = function(req,res) {
      pusher.trigger( 'ieacon-calc', 'checkOutDetected', {
      "name": req.body.name,
      "location": req.body.location
      });
      res.json({ message: 'checkOutDetected' });
    }

Вот мой файл маршрутов: ./api/routes/MetroRoutes

module.exports = function(app) {
      var todoList = require('../controllers/MetroController');

      // todoList Routes
      app.route('/checkin')
        .post(todoList.checkInDetected)

      app.route('/checkout')
        .post(todoList.checkOutDetected);
    };

1 Ответ

0 голосов
/ 10 мая 2018

Добавьте app.use(cors());, и оно должно работать.

При создании API с использованием узла всегда используйте cors.Прочитайте https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS, чтобы понять о CORS

...