使用http-proxy做的代理服务,为什么前端页面的访问的地址必须和请求接口的地址统一

1.使用node模块http-proxy请求代理服务时,能成功代理成功,但是问题是, 浏览器使用localhost:8001/index.html 访问页面,页面中的数据接口地址就必须写成 http://localhost:8001/CpyUser...

如果浏览器写成访问127.0.0.1:8001/index.html访问页面,页面中的数据接口地址就必须写成 http://127.0.0.1:8001/CpyUser...

有没有一种通用的方法:

服务代码如下:

// 新建一个代理 Proxy Server 对象
var proxy = httpProxy.createProxyServer({ target: 'http://192.168.1.102:8080/CpyService/bs' });

// 捕获异常
proxy.on('error', function (err, req, res) {
 res.writeHead(500, {
 'Content-Type': 'text/plain'
 });
 res.end('Something went wrong. And we are reporting a custom error message.');
});



var server = require('http').createServer(function(req, res) {
   
  var pathname = url.parse(req.url).pathname;  
 if(pathname.indexOf("CpyUser") > 0){
   console.log('代理服务', req.url, res)
  //  req.url = req.url.replace('/mspj-mall-admin', '')
  proxy.web(req, res); 
  // return;
} else {
  handler (req, res) // 处理静态资源的请求
}

var host = req.url;
host = url.parse(host); host = host.host;

console.log("host:" + req.headers.host);
console.log("client ip:" + (req.headers['x-forwarded-for'] || req.connection.remoteAddress));

});
阅读 9.3k
4 个回答

问题解决了,我只要将前端接口写成 var url = 'http://' + window.location.host + '/CpyUser/login' 可以了,无论是通过localhost:8001 访问我的页面还是通过IP访问我的页面,都是能够正常访问接口的。

没有.因为127.0.0.1 和localhost都是不一样的域名.虽然ip指向一样.
如果互相请求的话.也是跨域了.
不过你可以在后端设置允许跨域请求.那就无所谓了.

图片描述

我的理解是:
楼主意思是不想每次都去配置和改变接口访问的形式嘛。你的代码中,
关键点1 .traget应该是是固定死了反回的接口,如果你不想固定死,就直接写成"http://192.168.1.102:8080/",这样所有接口请求访问就会指向这个地址下面对应的接口
关键点2 代码中的 pathname那做了if条件判定,当然你每次访问的时候必须加上CpyUser这个后缀才能代理成功的嘛,取消if条件判定就可以了

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题