【问题标题】:Axios with Express "Request failed with status code 404"带有 Express 的 Axios “请求失败,状态码 404”
【发布时间】:2021-06-24 18:23:09
【问题描述】:

我是一名新开发人员,试图通过 Express、Express Router 和 Axios 了解路由器和控制器。

服务器(app.js):

var createError = require('http-errors');
var express = require('express');

var cors = require('cors');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');

var indexRouter = require('./routes/index');
var authRouter = require('./routes/auth');

var app = express();
app.use(cors());

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

// routes
app.use('/', indexRouter);
app.use('/login', authRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});

// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

路由器(auth.js):

var express = require('express');
var router = express.Router();

const controller = require("../controllers/auth.controller");

router.post('/login', controller.login);

module.exports = router;

控制器(auth.controller.js):

var axios = require('axios');

const url = "https://my-api-url.com";

module.exports = {
    login: (req, res) => {
        console.log('made login request');
        return axios.post(url + "/token", {
            username: req.body.username, 
            password: req.body.password
            }, {
                headers: { "Content-Type": "application/json" },
            }).then((response) => {
                res.send({
                    access_token: response.data.access_token
                });
            }).catch((err) => {
                console.log('failed to login');
        });
    }
};

我在控制台上收到“POST localhost 404 (Not Found)”和“Uncaught (in promise) Error: Request failed with status code 404”响应。但是,这非常有效:

app.js(没有路由器和控制器):

var createError = require('http-errors');
var express = require('express');
var axios = require('axios');
var cors = require('cors');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');

var app = express();
app.use(cors());

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

const url = "https://my-api-url.com";

// returns access token 
app.post('/login', (req, res) => {
    console.log('made login request!');
    axios.post(url + "/token", {username: req.body.username, password: req.body.password}, {
        headers: {"Content-Type": "application/json"},
    }).then((response) => {
        res.send({access_token: response.data.access_token});
    }).catch((err) => {
        console.log('failed to login');
    });
});

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});

// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

我可以继续使用最后一个代码段,因为它运行良好,但我想学习逻辑和最佳实践。我只是不确定我做错了什么。提前致谢。

【问题讨论】:

  • 您是否在两个路由器文件(indexRouter 和 authRouter)中创建了两个单独的路由器? express.Router()
  • 是的,我的 indexRouter 是 express 的开箱即用文件: var express = require('express'); var router = express.Router(); /* 获取主页。 */ router.get('/', function(req, res, next) { res.render('index', { title: 'Express' }); }); module.exports = 路由器;
  • 您没有在第二个代码中使用。两个单独的路由器实例可能会导致问题。使用一个路由器实例并以这种方式组织您的代码。对于初学者,您可以在第一个代码文件中注释 indexRouter 语句和相关代码并检查它是否有效。
  • 它没有用。 :(

标签: javascript node.js express axios


【解决方案1】:

app.js,当你使用路由器时:

app.use('/login', authRouter);

您的应用程序将以相对方式获取路由器内部的任何路由。

当你在你的路由器内时,你会以这种方式处理帖子:

router.post('/login', controller.login);

您的应用程序将等待这样的调用:http://localhost:3000/login/login/

如果你想用http://localhost:3000/login/打电话,你的路由器应该是这样的:

var express = require('express');
var router = express.Router();

const controller = require("../controllers/auth.controller");

router.post('/', controller.login);

module.exports = router;

【讨论】:

  • 谢谢!!!我是否对每个路由器对象都使用“/”?什么情况下我会改变它?
  • 您可以将一个路由器嵌套在另一个路由器中。每个路由器都有自己的相对路径。在这里,router.post('/', controller.login); 等待 http://localhost:3000/login/。因此,如果您想要http://localhost:3000/login/password,请在登录路由器文件中添加:router.post('/password', controller.password);
猜你喜欢
  • 2021-04-10
  • 2022-11-13
  • 2020-04-05
  • 1970-01-01
  • 2019-08-15
  • 1970-01-01
  • 1970-01-01
  • 2020-09-18
  • 2019-10-12
相关资源
最近更新 更多