Создание HTTP-запроса с использованием node.js выдает EAFNOSUPPORT - PullRequest
9 голосов
/ 06 января 2011

Я пытаюсь сделать простой запрос HTTP GET, используя node.js, но у меня возникают проблемы с использованием node.js v0.3.4-pre (то есть скомпилирован из HEAD по состоянию на это утро).Вот мой код:

    var cli = require('cli');
    var http = require('http');
    var url = require('url');

    cli.parse();

    cli.main(function(args, opts) {
            this.debug(args[0]);

            var siteUrl = url.parse(args[0]);
            var site = http.createClient(siteUrl.port, siteUrl.host);
            console.log(siteUrl);

            var request = site.request("GET", siteUrl.pathname, {'host' : siteUrl.host})
            request.end();

            request.on('response', function(response) {
                    response.setEncoding('utf8');
                    console.log('STATUS: ' + response.statusCode);
                    response.on('data', function(chunk) {
                            console.log("DATA: " + chunk);
                    });
            });
    });

Вот ошибка, которую я получаю:

node.js:68
      throw e; // process.nextTick error, or 'error' event on first tick
      ^
Error: EAFNOSUPPORT, Address family not supported by protocol family
    at doConnect (net.js:499:19)
    at Client.connect (net.js:652:30)
    at Client._ensureConnection (http.js:1033:10)
    at Client.request (http.js:1048:8)
    at Object.<anonymous> (/Users/paul/Desktop/readify.js:16:21)
    at /usr/local/lib/node/.npm/cli/0.2.3-2/package/cli.js:995:18
    at Object.main (/usr/local/lib/node/.npm/cli/0.2.3-2/package/cli.js:1000:9)
    at Object.<anonymous> (/Users/paul/Desktop/readify.js:10:5)
    at Module._compile (node.js:359:32)
    at Object..js (node.js:367:14)

Ответы [ 3 ]

12 голосов
/ 06 января 2011

Нашли ошибку, siteUrl.port будет undefined, если в URL-адресе явно не указан порт.Итак, решение:

var site = http.createClient(siteUrl.port || 80, siteUrl.host);
3 голосов
/ 06 января 2011
var site = http.createClient(siteUrl.port, siteUrl.host);

должно быть скорее

var site = http.createClient(siteUrl.port || 80, siteUrl.hostname);
1 голос
/ 22 июля 2012

Такое же сообщение об ошибке появилось на моей очень старой XPSP2-коробке для ЛЮБЫХ попыток подключения (). Например, ng не смог ничего сделать, и простые http-запросы не сработали.

При попытке найти решение этот пост появился повсюду, но это не та проблема.

В моем случае это было связано с тем, что WSAIoctl (...) всегда возвращал WSAEOPNOTSUPP при запросе WSAID_CONNECTEX, что казалось странным. Это привело меня к сообщению, в котором рекомендовалось выполнить «netsh winsock reset» из cmd, что устранило проблему!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...