vue解决跨域_java跨域解决方案

vue解决跨域_java跨域解决方案现阶段跨域方式有很多种,但是基本思想只有两种:绕过同源策略:历史遗留的产物,虽然思想很好,但是局限性太大(仅支持、因为数据是在中,所以携带数据小)。:通过反向代理绕过去,这是很完美的解决方案,加上会给服务器增加一点压力,不过这点压力问题并不大[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ddoEgRFd-1656482203293)(https://juejin.cn/)][外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4M4avsX0-1

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

前言

跨域是因为浏览器存在对不同源页面数据接收的限制。这种限制就是浏览器的同源策略

同源策略是浏览器的安全机制,跨域的原理就是通过各种方式避开浏览器的安全机制

使用

在项目开发时,对跨域的概念仅限于了解,所以没有注重过程,只注重结果。所以在开发项目时,使用的是市面上比较常用,并且能够一劳永逸的cors。虽然cors方法能够完美解决跨域问题,但是还是要秉持着对知识探索的态度,去深入理解跨域问题。

报错提示

这里我使用8080端口的客户端访问3000端口的服务器,结果报错。

原因是因为端口号不同产生跨域。

如果将服务器端口号改为8080就不会报错了。

Snipaste_2022-04-21_10-59-33.png

跨域方法

跨域的方法有corsProxy正向代理Nginx反向代理Jsonp

现阶段跨域方式有很多种,但是基本思想只有两种:

  • 绕过同源策略

    • Jsonp:历史遗留的产物,虽然思想很好,但是局限性太大(仅支持get、因为数据是在url中,所以携带数据小)。

      原理:
      	有三个标签不受同源策略影响:
      	<script src="xxx"></script>
      	<link herf="xxx"></link>
      	<img src="xxx"></img>
      实现:
          // 1.创建script
          var script = document.createElement('script')
          // 2.定义回调函数
          function getData(data) {
            // 调用函数返回的数据
            console.log(data);
          }
          // 3.设置src属性
          script.src = 'http://localhost:3000?callback=getData'
          // 4.让cript生效
          document.appendChild(script) 
      
    • Nginx:通过反向代理绕过去,这是很完美的解决方案,加上会给服务器增加一点压力,不过这点压力问题并不大

      如何理解反向代理:代理服务器代替目标服务器去接收并响应给客户端发起的请求。隐藏服务器

      ​ 发起请求:客户端向代理服务器发出请求,代理服务器再将请求转发给目标服务器

      ​ 响应数据:目标服务器向代理服务器响应数据,代理服务器再向数据响应给客户端

      很常用的方法,像网易、头条都使用nginx代理

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ddoEgRFd-1656482203293)(https://juejin.cn/)][外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4M4avsX0-1656482203293)(https://juejin.cn/)]

      这是我在chrome上看的某些文件。

      nginx使用:

      • 下载nginx

        直接到官网下载

        [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-gaMNC5wi-1656482203294)(https://juejin.cn/)]

      • 修改默认配置

        • 打开conf/nginx.conf

        • 配置代理端口

Snipaste_2022-04-21_11-48-14.png – 配置监听端口

Snipaste_2022-04-21_11-49-07.png

 > 输入 start nginx.exe 没有反应表示启动成功 
  • Proxy:通过正向代理绕过去,让服务器帮我们向服务器发送请求,因为跨域均存在于浏览器与服务器之间。只能在本地开发环境使用。

    如何理解正向代理:代理服务器代替客户端向服务器发起请求。隐藏客户端

    ​ 发起请求:代理服务器从客户端发出请求,向目标服务器发起请求。

    ​ 响应数据:目标服务器响应请求,代理服务器接收请求,并转发给客户端。

    日常使用的翻墙就是基于这个原理。

    一句话概述正向代理和方向代理:正向代理客户端,反向代理服务器。

    • main.js

      axios.defaults.baseURL = '/' 
      
    • vue.config.js

      module.exports = {
        devServer: {
          proxy: {
            '/': {
              target: 'http://localhost:3000', // 目标服务器
              changeOrigin: true
            }
          }
        }
      } 
      

      这里我使用的是webpack proxy,是webpack提供的代理服务,方便易用,但是只适用于开发阶段

      原理:在代理服务器传递数据给本地浏览器的过程中,两者同源,并不存在跨域行为,这时候浏览器就能正常接收数据

    • 此时,只要浏览器访问根路径,代理服务器就会向目标服务器发起请求。

    补充:CDN(内容分发网络)

    简单来说就是,用户发起请求,请求会发送到最适合的服务器上。比如说,我在广州发送请求,请求就会发送到广州的服务器上。优点类似京东快递,发货的时候会优先选择就近的京东仓库,所以物流速度很快,同样的CDN也是加快网络请求速度。

  • cors

    • 终级解决方案(IE9 以下除外)

    • 跨域资源共享 (Cross-Origin Resource Sharing, CORS),就是在服务器端的响应中加入额外的HTTP头,使浏览器能跨域访问资源。

      响应头需要设置的字段:Access-Control-Allow-Origin: * 
      
    • 我做项目时,使用方法是添加 cors 中间件

      // 引入cors
      const cors = require('cors')
      // 使用 cors()
      app.use(cors()) 
      

说明

跨域请求产生时,服务器是能够接收到数据的,并且也响应了数据,只不过在浏览器接收数据的时候,由于不同源的原因,出发了浏览器的安全机制,所以数据就被挡在浏览器外。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/187325.html原文链接:https://javaforall.net

(0)
上一篇 2026年4月19日 下午9:40
下一篇 2026年4月19日 下午9:46


相关推荐

  • 程序员不成熟的若干个特征

    程序员不成熟的若干个特征人成熟与不成熟跟年龄没有关系,人成熟不成熟,就是你能不能站在对方的角度去看待事物。就是能不能把我的世界变成你的世界。这个社会有很多的成年人,还没有脱离幼稚的行为。一点小事情就跟别人争来争去。人不成熟的第一个特征——就是立即要回报他不懂得只有春天播种,秋天才会收获。很多人在做任何事情的时候,刚刚付出一点点,马上就要得到回报。(学钢琴,学英语等等,刚开始就觉得难,发现不行,立即就要放弃。)做我们这个项目也是一样,很多人来做这个生意,开始没有什么成绩,就想着要放弃,有的人一个月放弃,有的人三个月放弃,有的

    2022年5月27日
    30
  • matlab读取tif图像并显示_matlab关闭窗口

    matlab读取tif图像并显示_matlab关闭窗口语法:info=imfinfo(filename,fmt)%输入图像名,图像的格式info=imfinfo(filename)%输入图像名 示例程序:info=imfinfo(‘C:\test1.jpg’) %返回图像信息,注意:输入·必须字符串info.Width                        …

    2022年10月5日
    7
  • 在CentOS / RHEL 7上找不到fuser命令

    在CentOS / RHEL 7上找不到fuser命令在 CentOS RHEL7 上找不到 fuser 命令 bash fuser commandnotfo

    2026年3月17日
    2
  • 侦察系列之匿名邮箱(短信)网站「建议收藏」

    侦察系列之匿名邮箱(短信)网站「建议收藏」1、ProtonMail:免费的加密电子邮箱https://mail.protonmail.com/2、mfk.app免费临时电子邮件地址https://www.8164.cc/3、隐私短信在线短信验证码接收码平台https://www.yinsiduanxin.com4、云短信验证码接收平台https://www.bfkdim.com/5、临时edu邮箱EDUMAILhttps://mail.mjj.edu.ge/6、Snapmail.cc临时邮箱https://www.s

    2022年10月10日
    6
  • oracle错误904解决方法_oracle错误12154

    oracle错误904解决方法_oracle错误12154案例情景——在一次C:\DocumentsandSettings\Administrator>explsxy/lsxy@lsxy_dbfile=E:\lsxy.dmpowner=lsxyExport:Release11.2.0.1.0-Productionon星期一11月2614:07:182012Copyright(c)1982,2009,Oracleand/…

    2025年12月11日
    5
  • 列式存储和行式存储的理解详解

    列式存储和行式存储的理解详解列式存储和行式存储的理解详解一 列式存储和行式存储二 列式存储和行式存储优比较理解三 列式存储优势四 小结什么时候应该使用行式存储 什么时候应该使用列式存储呢 叮嘟 这里是小啊呜的学习课程资料整理 好记性不如烂笔头 今天也是努力进步的一天 一起加油进阶吧

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号