前后端项目分离解决cors错误的方法详解
前言
前后端分离项目中接口请求会出现cors错误,引发cors错误的原因为跨域请求失败。
具体解决方法有配置类重写addCorsMappings方法、controller添加@CrossOrigin注解、使用nginx解决跨域请求
提示:以下是本篇文章正文内容,下面案例可供参考
一、什么是跨域请求
例如:http://192.168.1.100:8080为java项目服务器链接,当前端页面链接中传输协议(http、https)、ip地址、服务端口任有一个不同,即为跨域。
二、配置类重写addCorsMappings方法
1、CorsConfig配置类添加@Configuration注解
2、继承WebMvcConfigurer
3、重写addCorsMappings方法
完成后再启动项目时会自动加载
@Configuration
public class CorsConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry){
//设置允许跨域的路径
registry.addMapping ("/**")
//设置允许跨域请求的域名
.allowedOriginPatterns ("*")
//是否允许证书
.allowCredentials (true)
//设置允许的方法
.allowedMethods ("GET","POST")
//设置允许的header属性
.allowedHeaders ("*")
//允许跨域时间
.maxAge (3600);
}
}三、controller添加@CrossOrigin注解
注:添加@CrossOrigin注解解决跨域请求仅限springboot项目,且所有controller层添加太过繁琐,也可在父controller中添加,所有子controller继承

四、使用nginx解决跨域请求
1、http://nginx.org/en/download.html 从nginx官网下载解压

2、编辑conf下的nginx.conf
server {
listen 80; #配置nginx端口
server_name localhost; #需要链接的IP地址
location / {
root E:/xxx/xxx/webapp; #web代码存放路劲
index index.html; #启动nginx后打开的页面
}
#将含有/api的接口进行代理
location /api/ {
proxy_pass http://localhost:8081; #需要访问的后端链接
}3、启动nginx
打开cmd命令窗口进入到解压路径(含有nginx.exe的路径),输入nginx.exe启动nginx,在浏览器输入localhost:80即可打开前端代码页面。
直接关闭cmd窗口无法停止nginx,需在cmd输入nginx -s quit命令进行停止。
注:输入nginx.exe的页面无法继续输入命令行,需重新开启一个cmd窗口。
总结
这里对文章进行总结:
以上就是今天要讲的内容,本文仅仅简单介绍了跨域请求中cors错误的解决方法。
到此这篇关于前后端项目分离解决cors错误的文章就介绍到这了,更多相关前后端项目分离cors错误内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
mybatis-plus的自动填充时间的问题(添加到数据库的时间比当前时间多4个小时)
这篇文章主要介绍了mybatis-plus的自动填充时间的问题(添加到数据库的时间比当前时间多4个小时),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-09-09
Spring Security LDAP实现身份验证的项目实践
在本文中,我们涵盖了“使用 Spring Boot 的 Spring Security LDAP 身份验证示例”的所有理论和示例部分,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-08-08
spring配置文件解析失败报”cvc-elt.1: 找不到元素 ''''beans'''' 的声明”异常解决
这篇文章主要给大家介绍了关于spring配置文件解析失败报”cvc-elt.1: 找不到元素 'beans' 的声明”异常的解决方法,需要的朋友可以参考下2020-08-08


最新评论