美文网首页
Node 环境下 axios 的proxy配置 出坑攻略

Node 环境下 axios 的proxy配置 出坑攻略

作者: Ankh | 来源:发表于2020-09-29 17:53 被阅读0次

    为什么要写这一篇呢

    因为巧合的碰到,然后通过搜索依旧让我花费了很长的时间才解决这个问题,我相信陈旧的搜索结果一样无法满足即将看到这篇文章的人,所以我决定帮助你们。😝

    为什么会有这个问题

    因为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
    })
    

    Issue 参考链接

    相关文章

      网友评论

          本文标题:Node 环境下 axios 的proxy配置 出坑攻略

          本文链接:https://www.haomeiwen.com/subject/vjbeuktx.html