四种跨域解决方案

打印 上一主题 下一主题

主题 865|帖子 865|积分 2595

1.引出跨域

1.基本介绍


2.具体演示

1.启动之前学习过的springboot-furn项目


2.欣赏器直接访问 localhost:8081/furns 可以体现信息


3.启动前端项目,取消请求拦截器,这样设置,就会出现跨域



4.跨域原因



  • 当前端项目请求到后端,会返回跨域请求拦截
  • 原因是欣赏器默认实行同源策略,会克制读取localhost:8081的资源
2.跨域题目介绍

1.是什么?


2.同源策略


3.跨域流程

1.简单请求和非简单请求

1.简单请求


2.非简单请求(不满足简单请求的就黑白简单请求)

2.简单请求-跨域流程


3.非简单请求-跨域流程


4.非简单请求演示

1.这里的添加就黑白简单请求


2.测试请求,预检请求失败,不会发送真实请求


4.跨域解决方案

1.Nginx反向代理



2.设置服务器允许跨域




3.前端启用代理,设置同源


5.跨域实操

1.全局CORS设置

1.后端编写设置类 CorsConfig.java

  1. package com.sun.furn.config;
  2. import org.springframework.context.annotation.Bean;
  3. import org.springframework.context.annotation.Configuration;
  4. import org.springframework.web.cors.CorsConfiguration;
  5. import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
  6. import org.springframework.web.filter.CorsFilter;
  7. /**
  8. * Description: 全局跨域配置
  9. *
  10. * @Author sun
  11. * @Create 2024/5/15 10:42
  12. * @Version 1.0
  13. */
  14. // 全局跨域配置
  15. @Configuration
  16. public class CorsConfig {
  17.     @Bean
  18.     public CorsFilter corsFilter() {
  19.         // 创建跨域配置,添加 CORS 配置信息
  20.         final CorsConfiguration corsConfiguration = new CorsConfiguration();
  21.         // 跨域请求默认不包含 cookie,设置为 true 可以包含 cookie
  22.         corsConfiguration.setAllowCredentials(true);
  23.         // 支持哪些来源的请求跨域, 支持
  24.         corsConfiguration.addAllowedOriginPattern("*");
  25.         // corsConfiguration.addAllowedOrigin("*");
  26.         // 支持哪些头信息
  27.         corsConfiguration.addAllowedHeader("*");
  28.         // 支持哪些方法跨域
  29.         corsConfiguration.addAllowedMethod("*");
  30.         // 添加映射路径
  31.         final UrlBasedCorsConfigurationSource urlBasedCorsConfigurationSource
  32.                 = new UrlBasedCorsConfigurationSource();
  33.         // /** 是一个正则表达式,表示所有请求 the mapping pattern
  34.         // corsConfiguration 跨域配置
  35.         urlBasedCorsConfigurationSource.registerCorsConfiguration("/**", corsConfiguration);
  36.         // 返回新的 CorsFilter.
  37.         return new CorsFilter(urlBasedCorsConfigurationSource);
  38.     }
  39. }
复制代码
2.成功解决跨域


3.查看响应头,后端允许跨域


2.添加CORS设置类(只是跟上面的形式不同)

1.后端编写设置类 WebMvcConfig.java

  1. package com.sun.furn.config;
  2. /**
  3. * Description: 全局跨域配置
  4. *
  5. * @Author sun
  6. * @Create 2024/5/15 11:49
  7. * @Version 1.0
  8. */
  9. import org.springframework.context.annotation.Configuration;
  10. import org.springframework.web.servlet.config.annotation.CorsRegistry;
  11. import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
  12. @Configuration
  13. public class WebMvcConfig extends WebMvcConfigurationSupport {
  14.     @Override
  15.     public void addCorsMappings(CorsRegistry registry) {
  16.         registry.addMapping("/**") // 允许跨域访问的路径
  17.                 .allowedOriginPatterns("*") // 允许跨域访问的源
  18.                 .allowedMethods("POST", "GET", "PUT", "OPTIONS", "DELETE") // 允许请求方法
  19.                 .maxAge(3600) // 预检间隔时间
  20.                 .allowCredentials(true); // 是否发送cookie
  21.     }
  22. }
复制代码
2.成功解决跨域


3.使用Filter方法实现

1.后端创建一个过滤器 CorsFilter.java

  1. package com.sun.furn.filter;
  2. import javax.servlet.*;
  3. import javax.servlet.annotation.WebFilter;
  4. import javax.servlet.http.HttpServletRequest;
  5. import javax.servlet.http.HttpServletResponse;
  6. import java.io.IOException;
  7. /**
  8. * Description: 使用过滤器解决跨域问题
  9. *
  10. * @Author sun
  11. * @Create 2024/5/15 13:25
  12. * @Version 1.0
  13. */
  14. @WebFilter(urlPatterns = "*")
  15. public class CorsFilter implements Filter {
  16.     @Override
  17.     public void init(FilterConfig filterConfig) throws ServletException {
  18.     }
  19.     @Override
  20.     public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException {
  21.         HttpServletRequest httpRequest = (HttpServletRequest)request;
  22.         HttpServletResponse httpResponse = (HttpServletResponse) response;
  23.         httpResponse.setCharacterEncoding("UTF-8");
  24.         httpResponse.setContentType("application/json; charset=utf-8");
  25.         httpResponse.setHeader("Access-Control-Allow-Origin", "*");
  26.         httpResponse.setHeader("Access-Control-Allow-Credentials", "true");
  27.         httpResponse.setHeader("Access-Control-Allow-Methods", "*");
  28.         httpResponse.setHeader("Access-Control-Allow-Headers", "Content-Type,Authorization");
  29.         httpResponse.setHeader("Access-Control-Expose-Headers", "*");
  30.         filterChain.doFilter(httpRequest, httpResponse);
  31.     }
  32.     @Override
  33.     public void destroy() {
  34.     }
  35. }
复制代码
2.启动类添加 @ServletComponentScan 注解,扫描servlet组件


3.成功解决跨域


4.Vue项目启用代理

1.在vue.config.js中添加代理

  1. // 跨域配置
  2. module.exports = {
  3.   devServer: {
  4.     port: 9999,  // 本地服务端口
  5.     proxy: { //设置代理,必须填
  6.       '/api': { //设置拦截器 拦截器格式 斜杠+拦截器名字,名字可以自己定
  7.         target: 'http://localhost:8081', //代理的目标地址
  8.         changeOrigin: true, //是否设置同源,输入是的
  9.         pathRewrite: { //路径重写
  10.           '/api': '' //选择忽略拦截器里面的单词
  11.         }
  12.       }
  13.     }
  14.   }
  15. }
复制代码
2.修改请求以/api的方式发送请求


3.成功解决跨域



  • 这种方式就相当于是本机对携带/api的请求举行代理,请求携带 Sec-Fetch-Site:same-origin 表示允许跨域

6.跨域小结

1.同源策略限定内容


2.请求跨域了,到底发出去没有


3.form表单可以跨域提交的,但是Ajax请求不可以跨域请求


4.推荐跨域处理方式



  • 服务器端解决跨域
  • Nginx动静分离 + 反向代理

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

自由的羽毛

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表