Вопрос по node.js, node-http-proxy, javascript, http-proxy, http – Как использовать http-прокси node.js для регистрации HTTP-трафика на компьютере?

3

Я пытаюсь реализовать самый простой пример:

var http = require('http'),
var httpProxy = require('http-proxy');

httpProxy.createServer(function (req, res, proxy) {
    //
    // I would add logging here
    //
    proxy.proxyRequest(req, res, { host: 'www.google.com', port: 80 });
}).listen(18000);

Когда я настраиваю свой браузер на использование этого прокси-сервера и перехожу на www.google.com, я не получаю ответа. Что это я делаю не так?

Я использую Windows 7 Chrome

Можете указать какую ОС и какой браузер? Каждый обрабатывает прокси по-своему. badunk
Это работает для вас с последними изменениями в библиотеке? Похоже, сейчас обязательно пройтиtarget поле в опциях, в противном случае просто запуск приведенного выше кода дает мнеMust provide valid URL for target Ayush Goel

Ваш Ответ

2   ответа
0

поможет ли это, потому что размещенная информация действительно короткая. Но я нашел пост, что они обновили API ...

Вы можете проверить этот пост:

Обновление до node-http-proxy v0.5.0 http://blog.nodejitsu.com/updating-node-http-proxy

5

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

Я много скопировал изhttp://blog.nodejitsu.com/http-proxy-middlewares

var fs = require('fs'),
    http = require('http'),
    httpProxy = require('http-proxy'),

logger = function() {    
  // This will only run once
  var logFile = fs.createWriteStream('./requests.log');

  return function (request, response, next) { 
    // This will run on each request.
    logFile.write(JSON.stringify(request.headers, true, 2));
    next();
  }
}

httpProxy.createServer(
  logger(), // <-- Here is all the magic
  {
    hostnameOnly: true,
    router: {
      'example1.com': '127.0.0.1:8001', // server on localhost:8001
      'example2.com': '127.0.0.1:8002'  // server 2 on localhost:8002
  }
}).listen(8000);
Должно ли это все еще работать? Я пытаюсь регистрировать запросы при обращении к другим URL-адресам, но не могу понять ...
Это больше не работает, поскольку теперь в параметрах обязательно указывать какое-либо целевое или передовое поле. Запуск приведенного выше кода дает мне Должен предоставить действительный URL для Target.

Похожие вопросы