解决本地开发接口请求跨域问题4种方案

nodejs服务实现反向代理,解决本地开发接口请求跨域问题

前后端分离项目需要解决第一个问题就是,前端本地开发时如何解决通过ajax请求产生的跨域的问题。一般的做法是通过本地配置nginx反向代理进行处理的,除此之外,还可以通过nodejs来进行代理接口。当然,要实现这个前提是,前端开发环境必须运行在nodejs服务中,所幸的是,现在前端的开发自动化工具都是建立在nodejs上的,所以这个前提也不是很重要。


以上错误提示是由于AJAX方法涉及到 跨域 的问题导致!

由于没有在服务器环境里运行含有ajax方法的页面,而是直接通过浏览器打开(类似file:///的访问形式,即file协议)

本地页面ajax()请求本地页面,须通过服务器环境运行,类似这样:

http://127.0.0.1:8888/ajax/index.html

webpack-dev-server配置跨域方案

如果你项目是用webpack作为前端自动化构建工具的话,那么可以引用webpack-dev-server来进行配置跨域方案。webpack-dev-server是一个小型的nodejs服务器,是基于express框架的,用于实时监听和打包编译静态资源。其中里面有一个属性是proxy,是专门来配置代理请求接口的。

举个例子:

比如我现在通过webpack构建了一个本地开发环境,端口号是9000,现在我要在本地去请求(GET)http://jsonplaceholder.typicode.com/users地址获取数据,如果前端没有设置代理的话,请求会因为跨域请求失败。这时候通过如下配置,就可以正常请求了。

devServer: {

contentBase: __dirname + "/",

port: 9000,

proxy: {

"/users": {//需要代理的路径target: "http://jsonplaceholder.typicode.com",//需要代理的域名changeOrigin:true//必须配置为true,才能正确代理}

}

}

通过如上配置,然后在js里面这样请求就可以成功拿到数据了:

//使用fetch获取ajax请求fetch('/users')//填写路径即可.then(function(response) {returnresponse.json()

}).then(function(json) {

console.log('parsed json', json)

}).catch(function(ex) {

console.log('parsing failed', ex)

})

这是通过webpack-dev-server配置的代理方案,那如果没有webpack-dev-server服务,要如何配置代理方案呢?比如在gulp和fis环境中,要怎么设置nodejs的代理服务。这时候我们就得来追寻下webpack-dev-server代理的实现机制了。

http-proxy-middleware模块设置代理服务

如果仔细阅读webpack-dev-server的文档,就会发现其实webpack-dev-server的代理方案是引用了http-proxy-middleware模块来设置的。这里要注意的是http-proxy-middleware模块也是运行在nodejs服务,因此前端需要运行一个nodejs服务,这里以express为例子:

varexpress = require('express');varproxy = require('http-proxy-middleware');varapp = express();

app.use('/users', proxy({

target: "http://jsonplaceholder.typicode.com",

changeOrigin:true}));// 省略各种配置  ... ...app.listen(..., 9000);

如上面代码展示,我们就可以在本地端口9000访问到http://jsonplaceholder.typicode.com/users的数据,其请求接口和上面一直。其实这段代码跟webpack-dev-server代理很相似的,应该说一样的,因为本来就是同一个东西的。在这里就不做更多介绍了,如果需要了解更多直接去看官方文档https://github.com/chimurai/http-proxy-middleware

让新版Chrome支持本地跨域请求调试

提示无法进行跨域请求。这时候如果解决呢?其实可以通过Chrome的启动参数,来解决这个问题,让我们的本地联调测试更加方便。具体方法是:

1、创建一个Chrome的启动快捷方式;

2、右键点击快捷方式属性,然后在目标路径后面,添加以下参数:

–disable-web-security –user-data-dir=”e:\chromedev“

注意在最新版本的Chrome中,–user-data-dir参数也是必须要添加的,下划线部分可以随便指定到其他路径,这里保存是的Chrome的用户数据的。

nginx反向代理解决跨域设置

1、打开本地Host文件, C:\Windows\System32\drivers\etc\ hosts文件

配置本地域名:

127.0.0.1       qyh.xxx.com   //目的是浏览器访问使用域名 ,如果不懂就安装配置就可以

2、打开安装nginx配置文件 进行配置

server {

listen 80 default backlog=2048;

listen 443 ssl;

server_name qyh.citic.com;#这里的域名要跟HOST配置一致

#ssl on;

ssl_certificate d:/nginx-1.11.10/conf/server.crt;#HTTPS需要证书路径

ssl_certificate_key d:/nginx-1.11.10/conf/server.key;#HTTPS需要证书路径

ssl_protocols TLSv1 TLSv1.1 TLSv1.2;

ssl_ciphers ECDHE-RSA-AES256-SHA384:AES256-SHA256:RC4:HIGH:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!AESGCM;

ssl_prefer_server_ciphers on;

ssl_session_cache shared:SSL:100m;

ssl_session_timeout 100m;

location /{

root D:/xampp/htdocs;#默认请求路径

}

autoindex on;

index index.html index.htm index.shtml;

add_header Access-Control-Allow-Origin *;

add_header Access-Control-Allow-Headers X-Requested-With;

add_header Access-Control-Allow-Methods GET,POST,OPTIONS;

location /apis {

rewrite ^.+apis/?(.*)$ /$1 break;

include uwsgi_params;

proxy_pass https://qyhtest.citic.com/;#代理地址 --服务器接口域名

}

}

注意: server_name 要与HOST域名一致。

proxy_pass 是代理接口域名

listen监听443 及80端口

参考资料:

http://www.cnblogs.com/congxueda/p/6806375.html

http://blog.csdn.net/zhongshijun521/article/details/74331560

http://www.cnblogs.com/canfoo/p/6912306.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • 什么是跨域? 2.) 资源嵌入:、、、等dom标签,还有样式中background:url()、@font-fac...
    电影里的梦i阅读 2,361评论 0 5
  • 最近,我结实了一位美国外交官,相聊甚欢,好几次我到他家中做客,他给我的第一面长相就像是一个意大利人,黑眼珠和黑...
    安赛33阅读 237评论 0 0
  • 从未想过有一天我会和北大结缘,因为上学期间的我,成绩平平,最后以中专结束学习生涯。虽然学医三年,实习一年,最终没在...
    程程最爱颜如玉阅读 587评论 0 2
  • 首发:沐遥诗雨(MoyleSY) 文:李沐遥 端午粽子香 . 从江南飘来粽子香 让北方的我 沉迷于此 黏黏糯糯 濡...
    李沐遥阅读 214评论 0 2