繁体   English   中英

如何从 request 迁移到 axios

[英]How to migrate from request to axios

我正在使用 [https://github.com/huobiapi/REST-Node.js-demo][1] 连接到火币加密货币交易所,但我遇到了一些错误,例如:

 (node:29550) Warning: a promise was rejected with a non-error: [object Undefined]

 GET /v1/account/accounts/15548622/balance
  { Error: ESOCKETTIMEDOUT
 at ClientRequest.<anonymous> (/home/ttr/node_modules/request/request.js:816:19)
 at Object.onceWrapper (events.js:285:13)
 at ClientRequest.emit (events.js:197:13)
 at TLSSocket.emitRequestTimeout (_http_client.js:668:40)
 at Object.onceWrapper (events.js:285:13)
 at TLSSocket.emit (events.js:197:13)
 at TLSSocket.Socket._onTimeout (net.js:447:8)
 at listOnTimeout (timers.js:324:15)
 at processTimers (timers.js:268:5) code: 'ESOCKETTIMEDOUT', connect: false }

我相信它们与文件有关:

  framework/httpClient.js

可以将具有过时模块“请求”的模块更改为 axios 模块,因此我的错误可能会消失。

const http = require('http');
const request = require('request');
const moment = require('moment');
const logger = console;

var default_post_headers = {
    'content-type': 'application/json;charset=utf-8',
}

var agentOptions = {
    keepAlive: true,
    maxSockets: 256,
}

exports.get = function(url, options) {
   return new Promise((resolve, reject) => {
        options = options || {};
        var httpOptions = {
            url: url,
            method: 'get',
            timeout: options.timeout || 3000,
            headers: options.headers || default_post_headers,
            proxy: options.proxy || '',
            agentOptions: agentOptions
        }
        request.get(httpOptions, function(err, res, body) {
            if (err) {
                reject(err);
            } else {
                if (res.statusCode == 200) {
                    resolve(body);
                } else {
                    reject(res.statusCode);
                }
            }
        }).on('error', logger.error);
    });
}

exports.post = function(url, postdata, options) {
    return new Promise((resolve, reject) => {
        options = options || {};
        var httpOptions = {
            url: url,
            body: JSON.stringify(postdata),
            method: 'post',
            timeout: options.timeout || 3000,
            headers: options.headers || default_post_headers,
            proxy: options.proxy || '',
            agentOptions: agentOptions
        };
        request(httpOptions, function(err, res, body) {
            if (err) {
                reject(err);
            } else {
                if (res.statusCode == 200) {
                    resolve(body);
                } else {
                    reject(res.statusCode);
                }
            }
        }).on('error', logger.error);
    });
};

exports.form_post = function(url, postdata, options) {
    return new Promise((resolve, reject) => {
        options = options || {};
        var httpOptions = {
            url: url,
            form: postdata,
            method: 'post',
            timeout: options.timeout || 3000,
            headers: options.headers || default_post_headers,
            proxy: options.proxy || '',
            agentOptions: agentOptions
        };
        request(httpOptions, function(err, res, body) {
            if (err) {
                reject(err);
            } else {
                if (res.statusCode == 200) {
                    resolve(body);
                } else {
                    reject(res.statusCode);
                }
            }
        }).on('error', logger.error);
    });
};

到目前为止,我尝试过:

    return new Promise((resolve, reject) => {
        options = options || {};
        var httpOptions = {
            url: url,
            method: 'get',
            timeout: options.timeout || 3000,
            headers: options.headers || default_post_headers,
            proxy: options.proxy || '',
            agentOptions: agentOptions
        }
        axios.get(httpOptions, function(err, res, body) {
            if (err) {
                reject(err);
            } else {
                if (res.statusCode == 200) {
                    resolve(body);
                } else {
                    reject(res.statusCode);
                }
            }
        }).on('error', logger.error);
    });
} 

像这样的解决方案,但似乎它们的工作方式并不完全相同,所以没有奏效。

 [1]: https://github.com/huobiapi/REST-Node.js-demo

我刚刚从 request 迁移到 axios,我建议进行以下更改:

导入qs包

const httpsAgent = new https.Agent({
    rejectUnauthorized: false / true,
    cert: <your cert>
    key: <your key> })



var httpOptions = {
    url: url
    data: qs.stringify(postdata)
    method: 'post',
    timeout: options.timeout || 3000,
    headers: options.headers || default_post_headers,
    proxy: options.proxy || '', (not sure about this)
    httpsAgent };

这是发送请求的正确方法:

axios(httpOptions).then((resp)=>{
    // on success - for exmaple: console.log(response.status);
}).catch((err) => {
    //on failure - for example: return null;
});

您的请求一方面包含方法:发布,另一方面您执行 axios.get 如果您的请求有效负载包含方法字段,您可以只运行 axios(options)

我刚刚从模块中删除了蓝鸟,错误消失了。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM