文章目录 1.引出跨域 1.基本介绍 2.具体演示 1.启动之前学习过的springboot-furn项目 2.浏览器直接访问 [localhost:8081/furns](http://localhost:8081/furns) 可以显示信息 3.启动前端项目,取消请求拦截器,这样设置,就会出现跨域 4.跨域原因 2.跨域问题介绍 3.跨域流程 1.简单请求和非简单请求 1.简单请求 2.非简单请求(不满足简单请求的就是非简单请求) 2.简单请求-跨域流程 3.非简单请求-跨域流程 4.非简单请求演示 1.这里的添加就是非简单请求 2.测试请求,预检请求失败,不会发送真实请求 4.跨域解决方案 1.Nginx反向代理 2.配置服务器允许跨域 3.前端启用代理,配置同源 5.跨域实操 1.全局CORS配置 1.后端编写配置类 CorsConfig.java 2.成功解决跨域 3.查看响应头,后端允许跨域 2.添加CORS配置类(只是跟上面的形式不同) 1.后端编写配置类 WebMvcConfig.java 2.成功解决跨域 3.使用Filter方法实现 1.后端创建一个过滤器 CorsFilter.java 2.启动类添加 @ServletComponentScan 注解,扫描servlet组件 3.成功解决跨域 4.Vue项目启用代理 1.在vue.config.js中添加代理 2.修改请求以/api的方式发送请求 3.成功解决跨域 6.跨域小结 1.同源策略限制内容 2.请求跨域了,到底发出去没有 3.form表单可以跨域提交的,但是Ajax请求不可以跨域请求 4.推荐跨域处理方式
1.引出跨域
1.基本介绍
2.具体演示
1.启动之前学习过的springboot-furn项目
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
package com. sun. furn. config ; import org. springframework. context. annotation. Bean ;
import org. springframework. context. annotation. Configuration ;
import org. springframework. web. cors. CorsConfiguration ;
import org. springframework. web. cors. UrlBasedCorsConfigurationSource ;
import org. springframework. web. filter. CorsFilter ;
@Configuration
public class CorsConfig { @Bean public CorsFilter corsFilter ( ) { final CorsConfiguration corsConfiguration = new CorsConfiguration ( ) ; corsConfiguration. setAllowCredentials ( true ) ; corsConfiguration. addAllowedOriginPattern ( "*" ) ; corsConfiguration. addAllowedHeader ( "*" ) ; corsConfiguration. addAllowedMethod ( "*" ) ; final UrlBasedCorsConfigurationSource urlBasedCorsConfigurationSource= new UrlBasedCorsConfigurationSource ( ) ; urlBasedCorsConfigurationSource. registerCorsConfiguration ( "/**" , corsConfiguration) ; return new CorsFilter ( urlBasedCorsConfigurationSource) ; }
}
2.成功解决跨域
3.查看响应头,后端允许跨域
2.添加CORS配置类(只是跟上面的形式不同)
1.后端编写配置类 WebMvcConfig.java
package com. sun. furn. config ; import org. springframework. context. annotation. Configuration ;
import org. springframework. web. servlet. config. annotation. CorsRegistry ;
import org. springframework. web. servlet. config. annotation. WebMvcConfigurationSupport ; @Configuration
public class WebMvcConfig extends WebMvcConfigurationSupport { @Override public void addCorsMappings ( CorsRegistry registry) { registry. addMapping ( "/**" ) . allowedOriginPatterns ( "*" ) . allowedMethods ( "POST" , "GET" , "PUT" , "OPTIONS" , "DELETE" ) . maxAge ( 3600 ) . allowCredentials ( true ) ; }
}
2.成功解决跨域
3.使用Filter方法实现
1.后端创建一个过滤器 CorsFilter.java
package com. sun. furn. filter ; import javax. servlet. * ;
import javax. servlet. annotation. WebFilter ;
import javax. servlet. http. HttpServletRequest ;
import javax. servlet. http. HttpServletResponse ;
import java. io. IOException ;
@WebFilter ( urlPatterns = "*" )
public class CorsFilter implements Filter { @Override public void init ( FilterConfig filterConfig) throws ServletException { } @Override public void doFilter ( ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException , ServletException { HttpServletRequest httpRequest = ( HttpServletRequest ) request; HttpServletResponse httpResponse = ( HttpServletResponse ) response; httpResponse. setCharacterEncoding ( "UTF-8" ) ; httpResponse. setContentType ( "application/json; charset=utf-8" ) ; httpResponse. setHeader ( "Access-Control-Allow-Origin" , "*" ) ; httpResponse. setHeader ( "Access-Control-Allow-Credentials" , "true" ) ; httpResponse. setHeader ( "Access-Control-Allow-Methods" , "*" ) ; httpResponse. setHeader ( "Access-Control-Allow-Headers" , "Content-Type,Authorization" ) ; httpResponse. setHeader ( "Access-Control-Expose-Headers" , "*" ) ; filterChain. doFilter ( httpRequest, httpResponse) ; } @Override public void destroy ( ) { }
}
2.启动类添加 @ServletComponentScan 注解,扫描servlet组件
3.成功解决跨域
4.Vue项目启用代理
1.在vue.config.js中添加代理
module. exports = { devServer : { port : 9999 , proxy : { '/api' : { target : 'http://localhost:8081' , changeOrigin : true , pathRewrite : { '/api' : '' } } } }
}
2.修改请求以/api的方式发送请求
3.成功解决跨域
这种方式就相当于是本机对携带/api的请求进行代理,请求携带 Sec-Fetch-Site:same-origin 表示允许跨域
6.跨域小结
1.同源策略限制内容
2.请求跨域了,到底发出去没有
3.form表单可以跨域提交的,但是Ajax请求不可以跨域请求
4.推荐跨域处理方式