最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to use authenticated proxies with undici - Stack Overflow

programmeradmin1浏览0评论

Hello so am trying to use undici with a proxy but it doesn't work i tired this

const client = new Client({
  url: 'www.google',
  proxy: 'http://user:pass@host:port'
})

as well as this

const { HttpsProxyAgent } = require("https-proxy-agent");
const proxy = new HttpsProxyAgent("http://user:pass@host:port");
time = new Date()
client.request({
  path: '/',
  method: 'GET',
  httpsAgent: proxy 
},

but nothing seems to work

Hello so am trying to use undici with a proxy but it doesn't work i tired this

const client = new Client({
  url: 'www.google.',
  proxy: 'http://user:pass@host:port'
})

as well as this

const { HttpsProxyAgent } = require("https-proxy-agent");
const proxy = new HttpsProxyAgent("http://user:pass@host:port");
time = new Date()
client.request({
  path: '/',
  method: 'GET',
  httpsAgent: proxy 
},

but nothing seems to work

Share Improve this question asked Mar 3, 2021 at 15:10 Donald trump Donald trump 1111 silver badge10 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 6

here is my working implementation:

import { Dispatcher, fetch, ProxyAgent } from 'undici';

const proxyAgent = new ProxyAgent({
      uri: `http://${your_proxy_ip}:${your_proxy_port}`,
      token: `Basic ${Buffer.from(`${your_proxy_username}:${your_proxy_password}`).toString('base64')}`,
    });

fetch(your_url, {dispatcher: proxyAgent})

See this link here: https://github./nodejs/undici/blob/01302e6d2b2629cca4ad9327abe0f7a317f8399f/docs/best-practices/proxy.md#connect-with-authentication

import { Client } from 'undici'
import { createServer } from 'http'
import proxy from 'proxy'

const server = await buildServer()
const proxy = await buildProxy()

const serverUrl = `http://localhost:${server.address().port}`
const proxyUrl = `http://localhost:${proxy.address().port}`

proxy.authenticate = function (req, fn) {
  fn(null, req.headers['proxy-authorization'] === `Basic ${Buffer.from('user:pass').toString('base64')}`)
}

server.on('request', (req, res) => {
  console.log(req.url) // '/hello?foo=bar'
  res.setHeader('content-type', 'application/json')
  res.end(JSON.stringify({ hello: 'world' }))
})

const client = new Client(proxyUrl)

const response = await client.request({
  method: 'GET',
  path: serverUrl + '/hello?foo=bar',
  headers: {
    'proxy-authorization': `Basic ${Buffer.from('user:pass').toString('base64')}`
  }
})

response.body.setEncoding('utf8')
let data = ''
for await (const chunk of response.body) {
  data += chunk
}
console.log(response.statusCode) // 200
console.log(JSON.parse(data)) // { hello: 'world' }

server.close()
proxy.close()
client.close()

function buildServer () {
  return new Promise((resolve, reject) => {
    const server = createServer()
    server.listen(0, () => resolve(server))
  })
}

function buildProxy () {
  return new Promise((resolve, reject) => {
    const server = proxy(createServer())
    server.listen(0, () => resolve(server))
  })
}
发布评论

评论列表(0)

  1. 暂无评论