未加星标

vue几个常用跨域处理方式介绍

字体大小 | |
[前端(javascript) 所属分类 前端(javascript) | 发布者 店小二03 | 时间 | 作者 红领巾 ] 0人收藏点击收藏

设置express代理请求

在基于vue-cli的项目中,在开发环境配置(config/dev.env.js)中设置代理,能够将所有/apidomain开头的请求都通过npm run dev启动的express服务器重定向到目标接口

官方文档:https://vuejs-templates.github.io/webpack/proxy.html

proxyTable: {
'/apidomain':{
target:'http://localhost:prot',//或ip或域名。
changeOrigin:true,
pathRewrite: {
'^/apidomain': ''
}
}
},
若要通过IP在局域网访问h5,启动开发服务器的时候添加host参数即可
即package.json的dev命令配置如下

"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js --host 0.0.0.0",

关闭chrome安全策略实现跨域

windows中新建一个bat文件粘贴下面的命令即可以此模式打开

cd "C:\Program Files (x86)\Google\Chrome\Application"
chrome.exe --disable-web-security --user-data-dir=c:/CorsUserData

asp.net core 服务端的CORS跨域设置

官方文档:https://docs.microsoft.com/zh-cn/aspnet/core/security/cors

在实际设置中,因为在h5端添加header参数产生了预检(OPTIONS)请求,看了上述文章后将通用参数修改到了query参数中

1. 添加cors服务

public void ConfigureServices(IServiceCollection services)
{
//若只有部分接口则定义一个或多个命名的 CORS 策略,并在运行时按名称然后选择的策略,通过特性标记去设置跨域 详情见文档
services.AddCors();
}

2. 启用中间件

//读取配置文件中设置的允许跨域的域名 CorsOrigins为一个数组 设置["*"]则会允许所有
var origins = Configuration.GetSection("CorsOrigins").GetChildren().Select(s => s.Value).ToArray();
app.UseCors(e =>
{
e.WithOrigins(origins).AllowAnyHeader().AllowAnyMethod().AllowCredentials();
});

//Startup文件中Configuration对象的获取
public IConfiguration Configuration { get; }
public Startup()
{
var builder = new ConfigurationBuilder()//...AddJsonFile($"appsettings.json");
Configuration = builder.Build();
}

JSONP

JSONP只支持GET请求,CORS支持所有类型的HTTP请求。JSONP的优势在于支持老式浏览器,以及可以向不支持CORS的网站请求数据。
您可能感兴趣的文章:基于vue-resource jsonp跨域问题的解决方法vue.js使用代理和使用Nginx来解决跨域的问题vue-cli开发时,关于ajax跨域的解决方法(推荐)vue+springboot前后端分离实现单点登录跨域问题解决方法基于VUE移动音乐WEBAPP跨域请求失败的解决方法Nginx 解决WebApi跨域二次请求以及Vue单页面的问题vue解决跨域路由冲突问题思路解析vue2.0设置proxyTable使用axios进行跨域请求的方法vue+Java后端进行调试时解决跨域问题的方式vue使用axios跨域请求数据问题详解vue跨域解决方法

本文前端(javascript)相关术语:javascript是什么意思 javascript下载 javascript权威指南 javascript基础教程 javascript 正则表达式 javascript设计模式 javascript高级程序设计 精通javascript javascript教程

主题: JSONP服务器NginxChrome浏览器Java中间件数据VUTI
tags: 跨域,vue,dev,请求,CORS,Configuration,设置,解决,JSONP,webpack,public,apidomain,js,文档,方法
分页:12
转载请注明
本文标题:vue几个常用跨域处理方式介绍
本站链接:http://www.codesec.net/view/572474.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 前端(javascript) | 评论(0) | 阅读(21)