为什么要写这一篇呢
因为巧合
的碰到,然后通过搜索依旧让我花费了很长的时间才解决这个问题,我相信陈旧的搜索结果一样无法满足即将看到这篇文章的人,所以我决定帮助你们。😝
为什么会有这个问题
因为axios的请求默认并没有使用本机的代理设置
,所以那些需要通过代理的接口并不能正常访问,返回结果就是你Timeout设置有多长,它就停顿有多久。其实你可以通过request、http 等库很简单的跳过这个问题,因为他们的配置方式所搜即所得。
为什么还要死磕axios这个问题
没有放弃转从而转向使用其它库,那是因为axios 的功能很全面
,promise的集成很自然
,还有各种钩子函数
提供,避免了自己使用较原始的库进行手动封装的不必要劳力付出
目前解决方案的入坑点
node-tunnel
const axios = require('axios')
const tunnel = require('tunnel')
const tunnelProxy = tunnel.httpsOverHttp({
proxy: {
host: 'you_host',
port: 'you_port',
},
});
axios(url,{
proxy: false,
httpsAgent: tunnelProxy,
})
错误信息
tunneling socket could not be established, cause=Hostname/IP does not
match certificate's altnames
一个最后一次commit为 2018-09-11且最终到0.0.6版本的库是不值得信赖的,
当你看到这种方式的时候请直接跳过
axios-https-proxy-fix
const axios = require('axios-https-proxy-fix')
axios(url,{
proxy: {
host: '127.0.0.1',
port: '1080'
},
timeout: 10000
})
安装使用方式很简单,但该库并没有随着axios变更同步更新,停留在了0.17.1的版本
所以 -> 请跳过
唯一能够解决的方式是下面这种
host是如果是本机那就是127.0.0.1,至于端口取决你的代理设置
注意,添加上httpsAgent的时候,需要设置 proxy 为 false,这一点很重要
const axios = require("axios");
const HttpsProxyAgent = require("https-proxy-agent");
//
const httpsAgent = new HttpsProxyAgent(`http://${YOUR_HOST}:${YOUR_PORT}`);
const axios = Axios.create({
proxy:false,
httpsAgent
})
网友评论