Исправить ошибку Axios ECONNREFUSED на локальном домене без прокси - PullRequest
0 голосов
/ 09 января 2019

Я сталкиваюсь с этой глупой проблемой с Axios.

Я пытаюсь отправить локальный POST-запрос в мое основное локальное приложение Symfony с помощью следующего фрагмента кода, который представляет собой кошмарный сканер JS: Yuzu.fun - это мой локальный домен разработчиков с записью в / etc / hosts для ее разрешения, приложение работает на порту 80.

await axios.request({
  url: 'http://yuzu.fun/app_dev.php/api/path/to/endpoint',
  headers: {
    'key': 'xxxxxx'
  },
  method: 'post',
  proxy: false,
  data: {
    image_data: data
  }
})
.then(function (response) {
  map_hash = response.message;
  console.log('buildMap', map_hash);
})
.catch(function (error) {
  console.error('upload failed:', error);
});

Когда я запускаю свой скрипт, я получаю сообщение об ошибке:

upload failed: { Error: connect ECONNREFUSED 127.0.0.1:80
at Object._errnoException (util.js:1022:11)
at _exceptionWithHostPort (util.js:1044:20)
at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1198:14)
code: 'ECONNREFUSED',
errno: 'ECONNREFUSED',
syscall: 'connect',
address: '127.0.0.1',
port: 80,
config: 
 { adapter: [Function: httpAdapter],
 transformRequest: { '0': [Function: transformRequest] },
 transformResponse: { '0': [Function: transformResponse] },
 timeout: 0,
 xsrfCookieName: 'XSRF-TOKEN',
 xsrfHeaderName: 'X-XSRF-TOKEN',
 maxContentLength: -1,
 validateStatus: [Function: validateStatus],
 headers: 
  { Accept: 'application/json, text/plain, */*',
    'Content-Type': 'application/json;charset=utf-8',
    key: 'xxxxx',
    'User-Agent': 'axios/0.18.0',
    'Content-Length': 4173 },
 method: 'post',
 url: 'http://yuzu.fun/app_dev.php/api/path/to/endpoint',
 proxy: false,
 data: '{"image_data":"imagedatainbase64"}' },
request: 
 Writable {
 _writableState: 
  WritableState {
    objectMode: false,
    highWaterMark: 16384,
    finalCalled: false,
    needDrain: false,
    ending: false,
    ended: false,
    finished: false,
    destroyed: false,
    decodeStrings: true,
    defaultEncoding: 'utf8',
    length: 0,
    writing: false,
    corked: 0,
    sync: true,
    bufferProcessing: false,
    onwrite: [Function: bound onwrite],
    writecb: null,
    writelen: 0,
    bufferedRequest: null,
    lastBufferedRequest: null,
    pendingcb: 0,
    prefinished: false,
    errorEmitted: false,
    bufferedRequestCount: 0,
    corkedRequestsFree: [Object] },
 writable: true,
 domain: null,
 _events: 
  { response: [Function: handleResponse],
    error: [Function: handleRequestError] },
 _eventsCount: 2,
 _maxListeners: undefined,
 _options: 
  { maxRedirects: 21,
    maxBodyLength: 10485760,
    protocol: 'http:',
    path: '/app_dev.php/api/path/to/endpoint',
    method: 'post',
    headers: [Object],
    agent: undefined,
    auth: undefined,
    hostname: 'yuzu.fun',
    port: null,
    nativeProtocols: [Object],
    pathname: '/app_dev.php/api/path/to/endpoint' },
 _ended: false,
 _ending: true,
 _redirectCount: 0,
 _redirects: [],
 _requestBodyLength: 4173,
 _requestBodyBuffers: [ [Object] ],
 _onNativeResponse: [Function],
 _currentRequest: 
  ClientRequest {
    domain: null,
    _events: [Object],
    _eventsCount: 6,
    _maxListeners: undefined,
    output: [],
    outputEncodings: [],
    outputCallbacks: [],
    outputSize: 0,
    writable: true,
    _last: true,
    upgrading: false,
    chunkedEncoding: false,
    shouldKeepAlive: false,
    useChunkedEncodingByDefault: true,
    sendDate: false,
    _removedConnection: false,
    _removedContLen: false,
    _removedTE: false,
    _contentLength: null,
    _hasBody: true,
    _trailer: '',
    finished: false,
    _headerSent: true,
    socket: [Object],
    connection: [Object],
    _header: 'POST /app_dev.php/api/path/to/endpoint HTTP/1.1\r\nAccept: application/json, text/plain, */*\r\nContent-Type: application/json;charset=utf-8\r\nkey: xxxxx\r\nUser-Agent: axios/0.18.0\r\nContent-Length: 4173\r\nHost: yuzu.fun\r\nConnection: close\r\n\r\n',
    _onPendingData: [Function: noopPendingOutput],
    agent: [Object],
    socketPath: undefined,
    timeout: undefined,
    method: 'POST',
    path: '/app_dev.php/api/path/to/endpoint',
    _ended: false,
    res: null,
    aborted: undefined,
    timeoutCb: null,
    upgradeOrConnect: false,
    parser: null,
    maxHeadersCount: null,
    _redirectable: [Circular],
    [Symbol(outHeadersKey)]: [Object] },
 _currentUrl: 'http://yuzu.fun//app_dev.php/api/path/to/endpoint' },
response: undefined }

Я попытался отправить сообщение на случайную конечную точку, чтобы проверить, работало ли соединение при достижении действующего домена, и все в порядке, но оно не работает локально. Когда я проверяю stackoverflow или форумы, я вижу, что люди упоминают проблемы с прокси-серверами, поэтому я вынуждаю его к false, но я не думаю, что это меня беспокоит.

Этот код был впервые написан с request.post(), но мне нужны льготы Axios Promises. Когда код был написан с запросом, локальный домен был доступен правильно. Поэтому я исключаю тот факт, что кошмар может помешать разрешению домена.

У кого-нибудь есть идеи, что здесь может пойти не так?

Заранее спасибо!

...