.net跨域CORS问题处理

前后端分离项目有两种部署方式:

一、同网站部署,在前端iis网站下,新建应用程序;如:api,接口用域名+/api访问。

二、前后端项目分开部署,两个域名不同会遇到跨域问题,下面就详细说下解决方式;

CORS将请求分为两种:

简单请求:

请求方式:post、get、head

头部字段满足cors安全规范,详见W3C,可默认,若有自定义head字段,需要后台配置允许;

请求头的Content-Type为:1,text/plain    2,nultipart/form-data   3,application/x-www-form-urlencoded

复杂请求:非简单请求



后端代码:web.config 中配置 

<system.webServer>
    <httpProtocol>
      <customHeaders>
        <add name="Access-Control-Allow-Origin" value="http://vue.test.com" />前端访问域名
        <add name="Access-Control-Allow-Headers" value="Accept,token, Origin, x-www-form-urlencoded, Content-Type,Last-Modified,x-requested-with" />允许访问请求头
        <add name="Access-Control-Allow-Methods" value="GET, POST, PUT, DELETE, OPTIONS" />请求方式
        <add name="Access-Control-Allow-Credentials" value="true" /> <!--前端:withCredentials: true, // 跨域请求时发送Cookie-->如后端需要存cookie,则需要配置这个
      </customHeaders>
    </httpProtocol>



前端vue里面配置:

import axios from "axios";

import QS from 'qs';

axios.defaults.headers.post["Content-Type"] = "text/plain";

import {

    Message

  } from 'element-ui';``

import router from '@/router/index.js'

const flagUrl = window.location.href.includes('localhost')

const http = axios.create({

    baseURL: flagUrl ? 'http://localhost:8080' :'https://net.test.com', //域名

    withCredentials: true, // 跨域请求时发送Cookie,否则后台无法获取cookie值

    timeout: 5000, //响应时间

})

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值