首页 > 其他分享 >Spring Boot解决跨域问题(端口不一致)

Spring Boot解决跨域问题(端口不一致)

时间:2024-07-25 14:53:28浏览次数:16  
标签:跨域 Spring Boot 接口 cookie 注解 id CrossOrigin

目录

一、什么是跨域

二、跨域产生的原因

三、当遇到不同端口之间的跨域访问时

@CrossOrigin注解

添加注解

四、当解决完跨域问题发现发送请求时不带cookie

问题情况:

 解决:

五,注意


一、什么是跨域

跨域是指在浏览器中,当一个网页的脚本试图去访问另一个网页的资源时,如果这两个网页的域名、协议或端口不一致,就会发生跨域问题。

浏览器出于安全考虑,实施了同源策略,即限制不同源之间的交互。同源是指两个页面具有相同的协议、主机和端口号,跨域问题通常发生在以下情况。

  1. 不同子域之间的跨域访问,例如a.example.com和b.example.com之间的通信。
  2. 不同域名之间的跨域访问,例如example.com和example.net之间的通信。
  3. 使用不同协议进行通信,例如http和https之间的通信。
  4. 不同端口之间的跨域访问,例如example.com:8080和example.com:8888之间的通信。

二、跨域产生的原因

之所以产生跨域主要是因为浏览器同源策略的限制。
同源策略,它是由NetSpace提出的一个著名的安全策略。
当一个浏览器的两个tab页中分别打开来自百度和谷歌的页面,当浏览器的百度tab页执行一个脚本的时候会检查这个脚本是属于哪个页面的,即检查是否同源,只有和百度同源的脚本才会被执行。如果非同源,那么在请求数据时,浏览器会在控制台中报一个异常,提示拒绝访问。

三、当遇到不同端口之间的跨域访问时

@CrossOrigin注解

我们可以在特定的某些接口加上@CrossOrigin注解,表示该接口允许跨域访问。注:未加该注解的接口仍不允许跨域访问。

@CrossOrigin注解中的origins还可设置域名,表示只有该域名访问时允许跨域,如:@CrossOrigin(origins =“http://localhost:5173/”);
若origins未设置值,表示所有域名都可以跨域访问该接口

添加注解

如果只要跨域一个接口的话,可在该接口上添加注解



@RestController
@RequestMapping("/account")
public class AccountController {
 
    @CrossOrigin(origins = {"http://localhost:5173/"})
    @GetMapping("/{id}")
    public Account retrieve(@PathVariable Long id) {
        // ...
    }
 
    @DeleteMapping("/{id}")
    public void remove(@PathVariable Long id) {
        // ...
    }
}

 如果所有接口都要跨域的话可以再类上添加注释

@RestController
@CrossOrigin(origins = {"http://localhost:5173/"})
public class UserController {

    @Resource
    private UserService userService;

    @Resource
    private RedisTemplate<String, Object> redisTemplate;
    @GetMapping("/{id}")
    public Account retrieve(@PathVariable Long id) {
        // ...
    }
 
    @DeleteMapping("/{id}")
    public void remove(@PathVariable Long id) {
        // ...
    }


}

四、当解决完跨域问题发现发送请求时不带cookie

问题情况:

这是请求头没有带cookie,如图:

 这是请求头带cookie的情况

 解决:

1.前端:当遇到这种情况时,且是用axios请求时可以在axios页面添加这一行代码

// 允许携带cookie
axios.defaults.withCredentials=true

2.后端:并且修改@CrossOrigin注解

//修改之前
@CrossOrigin(origins = {"http://localhost:5173/"})
//修改之后 allowCredentials:是否允许携带cookie
@CrossOrigin(origins = {"http://localhost:5173/"}, allowCredentials = "true")

3.最后如果在接口的类上添加@CrossOrigin注解,并且如上设置后,有的接口携带cookie,有的接口没有携带cookie,可以去前端全局搜索withCredentials,看一看发送请求时里面的配置,如果如图设置withCredentials=false,给接口也不带cookie。


 

五,注意

说明: 文章中很多地方为了方便,Access-Control-Allow-Origin设置成了*,这个在开发测试的时候可以这么设置,但如果是生产环境,建议不要设置成*,最好是允许哪些域名访问就设置哪些,毕竟限制域名还是很有必要的。

标签:跨域,Spring,Boot,接口,cookie,注解,id,CrossOrigin
From: https://blog.csdn.net/2301_79540484/article/details/140605061

相关文章

  • Springboot网络安全宣传小程序 毕业设计源码70468
                         摘 要随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,网络安全宣传小程序被用户普遍使用,为方便用户能够......
  • SpringBoot + MyBatis 实现 MySQL 主从复制动态数据源切换
    概述在项目中的某些场景中,需要对数据库进行一些优化。常用的有如下的实现方法:读写分离、引入缓存技术、主从复制、分库分表等。今天来简单介绍一些如何在程序中实现动态切换数据源,可能某台服务器性能比较好,让流量多的方法执行切换到此数据源去操作等等。当然这种思想也可以扩展......
  • Java毕业设计:基于Springboot+vue的电影院管理系统
    【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享......
  • Java毕业设计:基于SpringBoot+Vue的养老院系统
    一、选题背景意义......
  • SpringBoot+@Validated实现参数验证(非空、类型、范围、格式等)-若依前后端导入Excel
    原文链接: 霸道的程序猿的博客(cnblogs.com)若依管理系统前后端分离版基于ElementUI和SpringBoot怎样实现Excel导入和导出:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/108278834SpringBoot+Vue实现excel导入带格式化的时间参数(moment格式化明天日期并设置el......
  • 基于springboot+vue.js+uniapp的小程序的英语学习交流平台附带文章源码部署视频讲解等
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaits系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......
  • 免费分享一套微信小程序图书馆座位预约管理系统(SpringBoot后端+Vue管理端)【论文+源
    大家好,我是java1234_小锋老师,看到一个不错的微信小程序图书馆座位预约管理系统(SpringBoot后端+Vue管理端),分享下哈。项目介绍随着移动互联网技术的飞速发展和智能设备的普及,图书馆服务模式正在经历深刻的变革。本论文旨在探讨如何利用微信小程序这一便捷高效的平台,开发一款......
  • Django+Bootstrip 卡片模板设计 经典精品
    下面是一个完整的卡片模板代码,包含所有元素,并使用Django的模板语言来处理状态字段的条件渲染。同时还包括示例视图和URL配置。完整的卡片模板<divclass="card"><!--卡片图片--><imgsrc="{{product_package.image_url}}"class="card-img-top"alt="产品图片">......
  • 使用 @Audited 增强Spring Boot 应用程序的数据审计能力
    介绍在SpringBoot开发的动态世界中,确保数据完整性和跟踪变化是至关重要的。实现这一目标的一个强大工具是@Audited注解。本文深入探讨了该注解的复杂性、其目的、实现步骤以及如何利用其功能进行有效的实体审计。理解@AuditedSpringBoot中的@Audited注解用于审计实体,提供对数......
  • springboot农村综合风貌展示平台92098(案例分析)+V可免费领取源代码
    目  录摘要1绪论1.1研究背景1.2 研究意义1.3系统开发目标2.农村综合风貌展示平台系统分析2.2系统功能分析2.3 系统用例分析2.4 业务流程分析2.5本章小结3农村综合风貌展示平台总体设计3.1系统架构设计3.2 系统模块设计3.3数据库......