Axios使用代理IP请求
问题描述
使用vue想要实现爬虫,需要通过代理ip来访问到目标网站,根据文档使用了axios的proxy配置却无效果。
问题出现的环境背景及自己尝试过哪些方法
网上搜索全部是关于proxyTable解决跨域的,没有有用信息。
直接使用proxy和引入tunnel都不行,分别使用http和https也都不行。结果就是访问后目标服务端获取到的ip仍然是本机原ip,非代理ip,将代理地址随便改错,也不会有任何报错。说明代理没有生效。
相关代码
代码如下:(目标网址隐藏了,百度的有跨域访问不了,只是占位)
// 方法1
axios({
url: 'http://www.baidu.com',
method: 'get',
proxy: {
host: '183.167.217.152',
port: 63000
}
}).then(res => {
console.log(res)
})
// 方法2
axios({
url: 'https://www.baidu.com/',
method: 'get',
proxy: false,
httpAgent: tunnel.httpOverHttp({proxy: {host: '183.167.217.152', port: '630001'}}),
httpsAgent: tunnel.httpsOverHttp({proxy: {host: '183.167.217.152', port: '630001'}})
}).then(res => {
console.log(res)
})
你期待的结果是什么?实际看到的错误信息又是什么?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
我第一次见这种写法,vue有关于proxy的配置文件啊,为什么要在axios里面配置?
我也遇到一样的问题,目标服务器依旧获取了本机的ip地址,代理没有意义,你有解决办法了么
axios
的proxy
配置项是设置里一个Proxy-Authorization
请求头httpAgent
更是给nodejs用的为什么不直接请求代理服务器地址呢