简单的html js node 前端直接使用反向代理软件
先放上已经打包好的地址
https://gitee.com/Amengxiaoya/node-proxy.git 切记 proxyConfig.json 设置代理 ip为自己的ipv4地址 (cmd+ipconfig)
再放上源码地址
https://gitee.com/Amengxiaoya/node-re-quest.git 有点小乱,我测试用的(该项目只用到一个proxy.js文件)。
下载后第一步 `cnpm install` 然后node的pkg库的打包命令 `pkg -t node14-win proxy.js`
主要的proxy.js文件源码
//代理
const querystring = require('querystring');
const util = require('util');
const http = require('http');
const request = require('request');
const formidable = require("formidable");
const path = require("path");
const fs = require("fs");
const FormData = require('form-data')
const {
hostIp,
apiPort,
redirUrl,
customQuery,
consoleConfig:{apiSuc,apiFail,apiMsg,removeFile,removeMsg}
} = JSON.parse(fs.readFileSync(process.cwd()+'/proxyConfig.json','utf-8'));
function saveFiles(req,options,callback){
const promiseCase=[];
var form = new formidable.IncomingForm();
form.keepExtensions = true;
form.multiples = true;
form.uploadDir = path.join(process.cwd());
form.parse(req, function(err, fields, files) {
//const formData = new FormData()
options.formData = {};
for (let key in fields) {
//formData.append(key, fields[key])
options.formData[key]=fields[key]
}
for (let key in files) {
let newFilepath='Tmp-'+files[key].originalFilename;
fs.renameSync(files[key].newFilename,newFilepath)
//formData.append(key, fs.createReadStream('./'+newFilepath))
options.formData[key]=fs.createReadStream('./'+newFilepath,{highWaterMark:9999999})
new Promise((rev)=>{
promiseCase.push(rev)
}).then(()=>{
fs.unlink('./'+newFilepath,function(err){
if(removeFile==="0"){
console.log(err?'清理临时文件异常':'删除临时图片成功');
}
if(removeMsg==="0"&&err){
console.log(err);
}
})
})
}
request(options, function(error, response, body){
callback(error, response, body)
for (let item of promiseCase) {
item()
}
promiseCase.splice(0,)
})
//pipe(fs.createWriteStream(files.file.originalFilename))//formData.pipe()
})
}
//创建代理服务
const httpServer = http.createServer((req, res) => {
res.setHeader('Access-Control-Allow-Origin', '*');
res.setHeader('Access-Control-Allow-Credentials', true);
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
res.setHeader('Access-Control-Allow-Headers', '*');
if (req.method == 'OPTIONS') {
// 回复OPTIONS
res.end('');
return
}
/* 正式代理 */
let options = {
method: req.method,
header:req.headers,
encoding:null
};
if(customQuery!=='-1'){
options.headers={};
for (let key in customQuery) {
options.headers[key]=req.headers[customQuery[key]]
}
}
options.url = redirUrl + req.url
function callback(error, response, body) {
res.setHeader('Content-Type', response.headers['content-type']);
res.statusCode = response.statusCode
if (!error) { //删除 && response.statusCode === 200
if(apiSuc==="0"){
console.log(req.url + '成功代理')
}
res.end(body);
} else {
if(apiFail==="0"){
console.log(req.url + '请求异常')
}
if(apiMsg==="0"){
console.log(error)
}
res.end("{'code':-1,'msg':'node请求异常'}");
}
}
if (options.method === 'GET') {
request(options, callback);
}else if (options.method === 'POST') {
if(/^multipart\/form-data/.test(req.headers['content-type'])){
saveFiles(req,options,callback)
}else{
// 定义了一个post变量,用于暂存请求体的信息
var post = '';
// 通过req的data事件监听函数,每当接受到请求体的数据,就累加到post变量中
req.on('data', function(chunk) {
post += chunk;
});
req.on('end', function() {
options.body=post
request(options, callback);
});
}
}
}).listen(apiPort, hostIp, () => {
console.log('开启代理---' + hostIp + ':' + apiPort + '---为---' + redirUrl,'by#2585266774@qq.com#')
});
简单的html js node 前端直接使用反向代理软件的更多相关文章
- node插件http-proxy实现反向代理
最近自己动手做了一个微信小程序,是直接买的腾讯云的小程序解决方案,怎么说那,用起来还是会遇到不少问题的,不过在交流群里还是会有很多人帮助你的. 闲话少说,因为要再做一个别的服务,就想直接用这台小程序的 ...
- 前端通过Nginx反向代理解决跨域问题
在前面写的一篇文章SpringMVC 跨域,我们探讨了什么是跨域问题以及SpringMVC怎么解决跨域问题,解决方式主要有如下三种方式: JSONP CORS WebSocket 可是这几种方式都是基 ...
- 前端使用 Nginx 反向代理彻底解决跨域问题
引入网址https://blog.csdn.net/larger5/article/details/81286324 1.请求后端数据失败 代码: <!DOCTYPE html> < ...
- 搞懂:前端跨域问题JS解决跨域问题VUE代理解决跨域问题原理
什么是跨域 跨域:一个域下的文档或脚本试图去请求另一个域下的资源 广义的跨域包含一下内容: 1.资源跳转(链接跳转,重定向跳转,表单提交) 2.资源请求(内部的引用,脚本script,图片img,fr ...
- node项目发布+域名及其二级域名配置+nginx反向代理+pm2
学习node的时候也写了一些demo.但是只是限于本地测试,从来没有发布.今天尝试发布项目. 需要准备的东西 node 项目:为了突出重点,说明主要问题.我只是拿express 写了很简单的demo. ...
- 一统江湖的大前端(2)—— Mock.js + Node.js 如何与后端潇洒分手
<一统江湖的大前端>系列是自己的前端学习笔记,旨在介绍javascript在非网页开发领域的应用案例和发现各类好玩的js库,不定期更新.如果你对前端的理解还是写写页面绑绑事件,那你真的是有 ...
- vue—你必须知道的 js数据类型 前端学习 CSS 居中 事件委托和this 让js调试更简单—console AMD && CMD 模式识别课程笔记(一) web攻击 web安全之XSS JSONP && CORS css 定位 react小结
vue—你必须知道的 目录 更多总结 猛戳这里 属性与方法 语法 计算属性 特殊属性 vue 样式绑定 vue事件处理器 表单控件绑定 父子组件通信 过渡效果 vue经验总结 javascript ...
- 使用webpack+vue.js构建前端工程化
参考文章:https://blog.csdn.net/qq_40208605/article/details/80661572 使用webpack+vue.js构建前端工程化本篇主要介绍三块知识点: ...
- HTML、CSS、JS在前端开发中都扮演怎样的角色
前端开发,需要经常接触 HTML.DOM.CSS.JS等,那么HTML.CSS.JS在前端开发中究竟扮演怎样的角色呢?以下是个人的一些观点... HTML:超文本标记语言 (Hyper Text Ma ...
随机推荐
- WEB前端基础之SCC(字体颜色背景-盒子模型)
目录 一:伪元素选择器 1.首字调整>>>:也是一种文档布局的方式 2.在文本的前面通过css动态渲染文本>>>:特殊文本无法选中 3.在文本的后面通过css动态渲 ...
- NGINX的动静分离;什么是负载均衡
目录 一:动静分离 二:负载均衡 一:动静分离 动静分离是指在 web 服务器架构中,将静态页面与动态页面或者静态内容接口和动态内容接口分开不同系统访问的架构设计方法,进而提示整个服务的访问性和可维护 ...
- Java中的String,StringBuilder,StringBuffer三者的区别?
package com.aaa.zxf.ajax.test; /** * 弄清楚 string stringBuilder StringBuffer 三者之间的关系? * * * 一. 三者都是用来对 ...
- Atcoder ARC-065
ARC065(2020.8.3) A 尛你 \(\%\%\%\) B 翻译是错的,自闭了好久.先并查集将地铁连接的连通块联通,再枚举每条道路边判断是否在同一连通块即可. C 这翻译不知道在讲什么,建议 ...
- 创建spring boot项目并添加多个模块时,启动报 错误: 找不到或无法加载主类
最近建个项目发现启动报,找不到或无法加载主类,想想肯定是自己配置出问题了,经过排查确实出问题了,(根pom中的bulid为移到子模块中去导致的),下面演示下正确的创建子模块的步奏 1. 创 ...
- Java 变量的声明及初始化
格式: 数据类型 变量名字1 , 变量名字2 ,--变量名字n ; 案例: int i 声明了一个整形的变量. double d 声明了一个double数据类型的变量 float f 声明了一个fl ...
- laravel操作Redis排序/删除/列表/随机/Hash/集合等方法全解
Song • 3563 次浏览 • 0 个回复 • 2017年10月简介 Redis模块负责与Redis数据库交互,并提供Redis的相关API支持: Redis模块提供redis与redis.con ...
- K8s多节点部署+负载均衡+keepalived ——囊萤映雪
K8s多节点部署+负载均衡+keepalived --囊萤映雪 1.多节点master2 部署 2.负载均衡部署+keepalived 1.多节点master2部署: #从master01节点上拷贝证 ...
- springcloud+gateway微服务整合swagger
单一的微服务集成swagger: maven: <dependency> <groupId>io.springfox</groupId> <artifactI ...
- CSS解决父级边框坍塌的问题
1. 浮动元素后面增加空的div 首先在父级标签内添加如下<div>标签 <div id="clear"></div> 然后在CSS中对该标签进 ...