使用node+express+http-proxy-middleware代理转发解决跨域,获取数据失败

发布于 2022-09-06 04:37:20 字数 2549 浏览 13 评论 0

如题,使用express+http-proxy-middleware代理拿不到数据

这是app.js的内容

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
// 代理插件
var proxy = require('http-proxy-middleware');
// 跨域插件
var cors = require('cors');

var index = require('./routes/index');
var users = require('./routes/users');

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

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

// uncomment after placing your favicon in /public
// app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
    extended: false
}));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', index);
app.use('/users', users);


// catch 404 and forward to error handler
app.use(function(req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

// 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');
});

// 设置代理
app.use('/api', proxy({
    target: 'https://api.douban.com',
    changeOrigin: true
}));
app.listen(4000, function() {
    console.log('http://localhost:4000')
});


module.exports = app;

抓取的是豆瓣音乐的api,然后客户端的代码如下

function ajax(url) {
            var xml = new XMLHttpRequest();

            xml.open('GET', url, true);

            xml.onreadystatechange = function() {
                if (xml.readyState == 4 && xml.status == 200) {
                    console.log(JSON.parse(xml.responseText));
                }
            }

            xml.send();
        }

        ajax('http://localhost:4000/v2/music/search?q=周杰伦')

然而报错,拿不到数据,跨域确实没有了,但是却拿不到数据。
图片描述

api接口地址是豆瓣音乐api,是可以正常打开的。不知道是不是我哪里写错了,大佬们帮看看哇,感激不尽。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

别低头,皇冠会掉 2022-09-13 04:37:20

api路径定义不对,读一下http-proxy-middleware的文档

var express = require('express');
// 代理插件
var proxy = require('http-proxy-middleware');

var app = express();

// 设置代理
app.use('/v2', proxy({
    target: 'https://api.douban.com/',
    changeOrigin: true
}));
app.listen(4000, function() {
    console.log('http://localhost:4000')
});
稀香 2022-09-13 04:37:20

http://localhost:4000/是什么鬼

甜扑 2022-09-13 04:37:20

折腾了一晚上,终于解决了。感谢大佬的帮助,不过他没在这里写答案,那我自己写下来吧。

再次经过大佬点拨,修改一下答案。

解决

如下图

clipboard.png

即把proxy的配置代码写在404配置之前。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文