node.js使用代理踩的坑最终的解决方案使用https和socks-proxy-agent解决

2024-01-10 08:36

本文主要是介绍node.js使用代理踩的坑最终的解决方案使用https和socks-proxy-agent解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安装环境

npm install https
npm install socks-proxy-agent

调用环境

const https = require('https');
const { SocksProxyAgent } = require('socks-proxy-agent');

定义一个公用请求方法

function httpsRequest(options, body) {return new Promise((resolve, reject) => {const req = https.request(options, (res) => {let responseData = '';res.on('data', (chunk) => {responseData += chunk;});res.on('end', () => {resolve(responseData); // 当收到完整的响应数据时,解析 Promise});});req.on('error', (error) => {reject(error); // 在请求错误时拒绝 Promise});if (body) {req.write(body); // 写入请求主体}req.end(); // 结束请求});
}

定义一个获取代理的方法

async function fetchAndPrintUrl() {const url = '获取json返回的socks5的代理';try {const response = await axios.get(url);return response.data} catch (error) {console.error('Error fetching the URL:', error);}
}

写一个实际掉用方法的方法

async function new_get_token(ak, sk, lujin, url, appid, code) {// 示例使用let method = 'POST';let offset = 0; // 如有需要,替换为实际的偏移量let dataObj = {appId: appid,code: code};// 使用 JSON.stringify 转换为 JSON 字符串let body = JSON.stringify(dataObj);let headers = encryption_data2(ak, sk, method, lujin, body, offset, appid);try {const portData = await fetchAndPrintUrl();const pp = portData.data[0];let ip = pp.ip;let port = pp.port;const socksProxyUrl = `socks5://${ip}:${port}`;// 忽略 SSL/TLS 证书验证const agent = new SocksProxyAgent(socksProxyUrl, {rejectUnauthorized: false  // 忽略 SSL/TLS 证书验证});const options = {hostname: ip,port: port,path: url,method: 'POST',headers: {'Content-Type': 'application/json','Content-Length': Buffer.byteLength(body),...headers},agent: agent  // 如果您没有使用代理,可以省略这一行};let response = await httpsRequest(options, body);return response.data; // 返回数据而不是打印} catch (error) {console.error('Error making request:', error);throw error; // 抛出错误}
}

CHATGPT协助整理文档

1. 定义一个通用的 HTTPS 请求方法

function httpsRequest(options, body) {// ...
}

这段代码定义了一个名为 httpsRequest 的函数,用于发起 HTTPS 请求。它利用 JavaScript 的 Promise 来处理异步操作,确保请求完成后再继续执行后续代码。这个函数接受两个参数:options(请求配置)和 body(请求体)。

  • new Promise((resolve, reject) => { ... }):创建一个新的 Promise 对象,用于处理异步操作。
  • https.request(options, (res) => { ... }):发起 HTTPS 请求,其中 options 包含了请求的配置信息(如 URL、请求方法、头部等)。
  • res.on('data', (chunk) => { ... }):当接收到数据块时触发,将数据块累加到 responseData 字符串中。
  • res.on('end', () => { ... }):当响应结束时触发,此时 resolve(responseData) 会解析 Promise,并返回完整的响应数据。
  • req.on('error', (error) => { ... }):监听请求过程中的错误,如有错误则通过 reject(error) 拒绝 Promise。
  • if (body) { req.write(body); }:如果有请求体,则将其写入请求中。
  • req.end();:结束请求。

2. 定义一个获取代理的方法

async function fetchAndPrintUrl() {// ...
}

这个异步函数 fetchAndPrintUrl 用于获取一个 URL,并返回其 JSON 响应中的 socks5 代理信息。

  • const url = '获取json返回的socks5的代理';:这里应该是一个实际的 URL,用于请求 socks5 代理信息。
  • const response = await axios.get(url);:使用 axios 库发起 GET 请求,获取 URL 的内容。
  • return response.data:返回响应的数据部分。
  • catch (error) { ... }:捕获并处理任何错误。

3. 写一个实际调用方法的方法

async function new_get_token(ak, sk, lujin, url, appid, code) {// ...
}

这个异步函数 new_get_token 用于发送一个特定的 HTTPS 请求,并返回其响应。

  • 参数包括 ak(Access Key),sk(Secret Key),lujin(路径),url(请求的 URL),appidcode(应用程序特定的参数)。
  • encryption_data2(...):这看起来是一个自定义函数,用于生成请求的头部信息。
  • fetchAndPrintUrl():调用前面定义的函数来获取代理信息。
  • const agent = new SocksProxyAgent(socksProxyUrl, { ... }):创建一个代理代理,用于发送请求。
  • const options = { ... }:设置请求的配置信息。
  • let response = await httpsRequest(options, body);:使用前面定义的 httpsRequest 函数发起请求。
  • return response.data;:返回请求的响应数据。
  • catch (error) { ... }:捕获并处理任何错误。

这篇关于node.js使用代理踩的坑最终的解决方案使用https和socks-proxy-agent解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/590191

相关文章

Spring Security常见问题及解决方案

《SpringSecurity常见问题及解决方案》SpringSecurity是Spring生态的安全框架,提供认证、授权及攻击防护,支持JWT、OAuth2集成,适用于保护Spring应用,需配置... 目录Spring Security 简介Spring Security 核心概念1. ​Securit

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

SpringBoot整合Dubbo+ZK注册失败的坑及解决

《SpringBoot整合Dubbo+ZK注册失败的坑及解决》使用Dubbo框架时,需在公共pom添加依赖,启动类加@EnableDubbo,实现类用@DubboService替代@Service,配... 目录1.先看下公共的pom(maven创建的pom工程)2.启动类上加@EnableDubbo3.实

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处