小白看过来:如何解决跨域的问题

浏览器跨域-原因及解决方案

目标

掌握跨域的原因;复习常用的解决方案;

浏览器跨域

如何判断一个浏览器的请求是否跨域?

在A地址(发起请求的页面地址)向B地址(要请求的目标页面地址)发起请求时,

如果A地址和B地址在: 协议 域名 端口  不全相同,则说明请求是跨域的;

跨域请求在浏览器中是非常常见的现象!

跨域请报错的原因

请求是跨域的,并不一定会报错。普通的图片请求,css文件请求是不会报错的

跨域请求出现错误的条件: 浏览器同源策略  &&  请求类型是ajax类型

解决方案

  • 前端用JSONP方式去发请求(jsonp不是ajax请求)
  • 后端写代码(CORS)在响应中添加必要的响应头,让响应回来之后浏览器不报错
  • 代理转发

小结
浏览器发起跨域请求是很常见的;
浏览器的跨域请求报错的原因是: 浏览器同源策略 && 请求是ajax类型  && 请求确实跨域了
跨域-Vue-Cli配置代理转发
目标
通过配置vue-cli请求代理解决开发环境下的跨域问题
vue-cli中集成的跨域解决方案

思路:

  1. vue-cli脚手架工具在启动时,会开启一个前端项目的服务器。在同一局域网中的用户都可以通过ip地址来访问。
  2. vue-cli脚手架支持配置一个代理: 将指定的类型请求,转发到目标服务器。
  3. 代理服务和前端服务之间由于协议域名端口三者统一不存在跨域问题,可以直接发送请求
  4. 代理服务和后端服务之间由于并不经过浏览器没有同源策略的限制,可以直接发送请求

这样,我们就可以通过服务器代理做接口转发,在开发环境下解决跨域问题,看起来好像挺复杂,其实vue-cli已经为我们内置了该技术,我们只需要按照要求配置一下即可。

vue-cli解决跨域配置说明

vue.config.js配置文件中,有一项是devServer,它就是我们下边要操作的主角。

module.exports = {
  devServer: {
    // ... 省略
    // 代理配置
    proxy: {
        // 如果请求地址以/api打头,就出触发代理机制
        // http://localhost:9588/api/login -> http://线上的地址/api/login
        '/api': {
          target: 'http://线上的地址' // 我们要代理的真实接口地址
        }
      }
    }
  }
}

去掉axios基地址

({
  timeout: 5000
	// baseURL: ''
})

重启项目,验证结果

  1. 修改了配置文件,一定要重启前端项目
  2. 再次测试登陆接口,我们发现:跨域问题已经解决了

小结

  1. vue-cli集成了跨域代理功能------ 只能用在开发阶段
  2. vue.config.js文件中,在devServe下按指定格式配置了proxy,再重启项目即可。

特别强调:

axios的基地址baseUrl必须是相对地址,而不能是绝对地址

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
nginx提示403 Forbidden是指服务器拒绝访问某个资源或执行某个操作的错误。而关于跨域问题,nginx可以通过配置反向代理来解决。引用和引用都提到了nginx反向代理解决前端跨域问题。 为了解决跨域问题,可以在nginx配置文件中添加以下配置: ``` location /api { proxy_pass http://backend_server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } ``` 上述配置将请求转发给后端服务器,并在请求头中添加必要的信息。其中,`/api`是前端访问后端接口的URL前缀,`backend_server`是后端服务器的地址。 这样配置后,在前端访问接口时,只需要将接口的URL改为`/api/接口路径`即可。 需要注意的是,配置完成后,需要重启nginx使配置生效。 以上是解决nginx提示403 Forbidden跨域问题的方法。希望对您有帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [项目部署问题:xftp无法连接服务器、Nginx403 Forbidden解决、nginx反向代理解决前端跨域问题](https://blog.csdn.net/jcoiwenwfkowe/article/details/117867869)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [nginx访问静态资源403 forbidden的问题](https://blog.csdn.net/weixin_43358050/article/details/127320742)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值