跨域对于前端来说是一个老大难的问题,许多方法如jsonpdocument.domain + iframe...都有或多或少的问题,一个最佳实践就是通过服务器nginx做反向代理,但奈何不懂相关知识,就一直琢磨着使用 node.js来做。

3月28更新:

在实现完功能后,我考虑将它做成一个可供任意项目调用的模块,简化其使用方法,预想的调用方式为:

**start.js**
````
const webProxy = require('./webProxy').webProxy webProxy(targetUrl, localPort) ````

在CMD中切换到文件所在地址,键入:node start.js开启服务

下载地址:这里

配置http服务器和 http-proxy 转发请求

const http = require('http'),
httpProxy = require('http-proxy'),
fs = require('fs'),
url = require('url'),
path = require('path'),
mime = require('./mime').types; let proxy = httpProxy.createProxyServer({
target: 'http://192.168.1.30:6760',
secure: false
}) proxy.on('error', function (err, request, response) {
res.writeHead(500, {
'Content-Type': 'text/plain'
})
console.log(err)
res.end('Something went wrong.')
}) let server = http.createServer((request, response)=> {
var pathName = url.parse(request.url).pathname;
var realPath = request.url.substring(1);
var extName = realPath;
var indexOfQuestionMark = extName.indexOf('?'); if(indexOfQuestionMark >= 0){
extName = extName.substring(0, indexOfQuestionMark);
realPath = realPath.substring(0, indexOfQuestionMark);
} extName = path.extname(extName);
extName = extName ? extName.slice(1) : 'unknown'; if(/\/api\/.*$/.test(pathName)){
proxy.web(request, response);
return;
} if(!fs.existsSync(realPath)){
response.writeHead(404, {'content-type': 'text/plain'});
response.write('The request URL:' + realPath + ' could not be found.');
response.end();
return;
} fs.readFile(realPath, 'binary', function(err, file){
if(err){
response.writeHead(500, {'content-type': 'text/plain'});
response.end(err);
return;
} var contentType = mime[extName] || 'text/plain';
response.writeHead(200, {'content-type': contentType});
response.write(file, 'binary');
response.end();
});
}); console.log('listening on port 9060') server.listen(9060);

mime.js

exports.types = {
"css": "text/css",
"gif": "image/gif",
"html": "text/html",
"ico": "image/x-icon",
"jpeg": "image/jpeg",
"jpg": "image/jpeg",
"js": "text/javascript",
"json": "application/json",
"pdf": "application/pdf",
"png": "image/png",
"svg": "image/svg+xml",
"swf": "application/x-shockwave-flash",
"tiff": "image/tiff",
"txt": "text/plain",
"wav": "audio/x-wav",
"wma": "audio/x-ms-wma",
"wmv": "video/x-ms-wmv",
"xml": "text/xml",
"woff": "application/x-woff",
"woff2": "application/x-woff2",
"tff": "application/x-font-truetype",
"otf": "application/x-font-opentype",
"eot": "application/vnd.ms-fontobject"
};

项目工程结构如图

配置说明

基于node.js实现服务器的反向代理,核心步骤分为:

  • 通过http模块搭建本地服务器,使用fs模块读取本地.html.js.css等文件;
  • 使用http-proxy插件完成代理,基本用法可以在这里找到。
  • 通过 pathname 找到用于发送ajax 请求的api 地址,拦截请求,通过http-proxy模块转发。
````
if(/\/api\/.*$/.test(pathName)){
proxy.web(request, response);
return;
}
````
  • 当链接如右所示:http://localhost:9060/view/index.html?id=5,拿到的扩展名(变量extname)会有bug,所以这里先去掉了"?"后面的数据。
````
var indexOfQuestionMark = extName.indexOf('?'); if(indexOfQuestionMark >= 0){
extName = extName.substring(0, indexOfQuestionMark);
realPath = realPath.substring(0, indexOfQuestionMark);
}
````

其他

通过 node.js内置的服务器和第三方插件,我们完成了反向代理服务器,在其他文件不进行任何改动的情况下完成了跨域请求。但同时,又有了新的思考:

1、 每次启动服务都要键入node proxy.js, 非常麻烦,有没有简便方法?

2、 是否可以和gulp等构建工具配合使用?

3、 如何使用vue 之类的框架?

留待优化......

文章部分引用:

http://www.cnblogs.com/shawn-xie/archive/2013/06/06/3121173.html

https://segmentfault.com/a/1190000005101903

感谢!!!

【Node】node.js实现服务器的反向代理,解决跨域问题的更多相关文章

  1. windows环境下 nginx+iis 反向代理解决跨域问题

    项目基本完成,是时候花点时间整理一下最近的姿势了 1 什么是跨域? 网上对于跨域的概念会有大篇幅的文章去解释,似乎有点玄乎,初学者很容易对这个概念产生恐惧,跨域其实很简单,其实只要知道一点,无法跨域访 ...

  2. nginx反向代理解决跨域问题

    跨域:浏览器从一个域名的网页去请求另一个域名的资源时,域名.端口.协议任一不同,都是跨域 . 下表格为前后端分离的域名,技术信息:   域名 服务器 使用技术 前端 http://b.yynf.com ...

  3. 前端通过Nginx反向代理解决跨域问题

    在前面写的一篇文章SpringMVC 跨域,我们探讨了什么是跨域问题以及SpringMVC怎么解决跨域问题,解决方式主要有如下三种方式: JSONP CORS WebSocket 可是这几种方式都是基 ...

  4. 利用nginx 反向代理解决跨域问题

    说到nginx,不得不说真的很强大,也带来很多便利用于解决一些头疼的难题. 一般来说可以用来做:静态页面的服务器.静态文件缓存服务器.网站反向代理.负载均衡服务器等等,而且实现这一切,基本只需要改改那 ...

  5. nginx反向代理解决跨域

    nginx作为反向代理服务器,就是把http请求转发到另一个或者一些服务器上.通过把本地一个url前缀映射到要跨域访问的web服务器上,就可以实现跨域访问.对于浏览器来说,访问的就是同源服务器上的一个 ...

  6. Nginx 反向代理解决跨域问题分析

    当你遇到跨域问题,不要立刻就选择复制去尝试.请详细看完这篇文章再处理 .我相信它能帮到你. 分析前准备: 前端网站地址:http://localhost:8080 服务端网址:http://local ...

  7. webpack-dev-server 设置反向代理解决跨域问题

    一.设置代理的原因 现在对前端开发的要求越来越高,并且随着自动化以及模块化的 诞生,前后端开发模式越来越流行.后端只负责接口,前端负责数据展示.逻辑处理.但是前后端开发模式,有一个重要的问题,就是跨域 ...

  8. nginx反向代理解决跨域问题,使本地调试更方便

    我们可能都会遇到一个这样的问题,线上环境是https://...,本地启动了项目,域名是localhost:8000等,本地想要访问线上的接口,直接在本地调试,却提示跨域,这个时候我们可以配置ngin ...

  9. vue反向代理解决跨域

    问题描述 在项目开发的时候,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们现在使用vue-cli进行项目打包的时候,我们在本地启动服务器后,比如本地开发服务下是 http ...

  10. wamp2.4.4 如何配置虚拟主机及反向代理(解决跨域问题)

    一.找到安装目录下的httpd.conf文件 1. 删除Include conf/extra/httpd-vhosts.conf前面的#号(开启虚拟主机的配置) 2. 删除LoadModule pro ...

随机推荐

  1. Bean标签的常用属性

    -----------------siwuxie095 Bean 标签的常用属性 1.id 属性:Bean 的唯一标识名,必须以字母开头,且不能 包含特殊字符 2.class 属性:用来定义类的全限定 ...

  2. JAVA获取时间的方式

      1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 ...

  3. Linux Terminator

    NAME Terminator - Multiple GNOME terminals in one window SYNOPSIS terminator [options] DESCRIPTION T ...

  4. Visual Studio工具 vcpkg简介

    博客参考: https://blog.csdn.net/cjmqas/article/details/79282847#43-%E7%A7%BB%E9%99%A4%E5%85%A8%E5%B1%80% ...

  5. Java 设计模式系列(十二)策略模式(Strategy)

    Java 设计模式系列(十二)策略模式(Strategy) 策略模式属于对象的行为模式.其用意是针对一组算法,将每一个算法封装到具有共同接口的独立的类中,从而使得它们可以相互替换.策略模式使得算法可以 ...

  6. Java Thread系列(十)Future 模式

    Java Thread系列(十)Future 模式 Future 模式适合在处理很耗时的业务逻辑时进行使用,可以有效的减少系统的响应时间,提高系统的吞吐量. 一.Future 模式核心思想 如下的请求 ...

  7. 使用vim鼠标右键无法粘贴问题解决

    问题: Debian中通过终端使用vim,无法通过鼠标粘贴.这是由于一项默认的鼠标配置导致. 解决方法: vi /usr/share/vim/vim80/defaults.vim 查找set mous ...

  8. jdbc注册驱动 class.forName()

    从源码 D:\Javasoftware\MySql\mysql\mysql-connector-java-5.1.7\src\com\mysql\jdbc\Driver.java class.forN ...

  9. dns记录类型(转)

    NS:(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串.通过主机名,最终 ...

  10. Shell脚本传递带有空格的参数[摘录自网络]

    参数处理 说明 $# 传递到脚本的参数个数 $* 以一个单字符串显示所有向脚本传递的参数 $$ 脚本运行的当前进程ID号 $! 后台运行的最后一个进程的ID号 $@ 与$#相同,但是使用时加引号,并在 ...