当前位置: 首页 > 工具软件 > Object-proxy > 使用案例 >

使用http-proxy-middleware解决代理中cookie登录问题

笪栋
2023-12-01


const proxy = require('http-proxy-middleware');
const app = express();

let origin = 'http://www.baidu.com'
let host = 'www.baidu.com'

const localProxy = proxy({
  target: origin,
  changeOrigin: true,
  autoRewrite: true,
  headers: {
    host: host
  },
  onProxyReq (proxyReq, req) {
    // 将本地请求的头信息复制一遍给代理。
    // 包含cookie信息,这样就能用登录后的cookie请求相关资源
    Object.keys(req.headers).forEach(function (key) {
      proxyReq.setHeader(key, req.headers[key])
    })
    // 代理的host 设置成被代理服务的,解决跨域访问
    proxyReq.setHeader('Host', host)
  },
  onProxyRes (proxyRes, req, res) {
    // 将服务器返回的头信息,复制一遍给本地请求的响应。
    // 这样就能实现 执行完登录后,本地的返回请求中也有相关cookie,从而实现登录功能代理。
    Object.keys(proxyRes.headers).forEach(function (key) {
      res.append(key, proxyRes.headers[key])
    })
  }
})

app.use(['/v3', '/media'], localProxy)  //设置哪些请求使用该代理, 多个匹配规则以‘,’分割
 

 类似资料: