前后端项目分离解决cors错误

前后端项目分离解决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错误的解决方法。

  • 22
    点赞
  • 65
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
CORS(跨域资源共享)错误是指在使用XMLHttpRequest(XHR)进行跨域请求时出现的错误。在浏览器中,为了保护用户的安全,限制了跨域请求,即无法通过XHR直接从一个域名向另一个域名发起请求。然而,在某些情况下,我们可能需要进行跨域请求,这时就会出现CORS错误CORS错误主要有以下几种类型: 1. 简单请求(Simple Request)错误:简单请求是指满足一些特定条件的跨域请求。例如,使用GET、POST、HEAD方法之一,并且只使用了允许的头部字段等。如果在简单请求中出现CORS错误,通常是因为后端服务器未正确设置CORS响应头部,如Access-Control-Allow-Origin。 2. 预检请求(Preflight Request)错误:预检请求是指满足一些复杂条件的跨域请求。例如,使用了PUT、DELETE等非简单方法,或者使用了自定义的请求头部字段。在发送预检请求时,浏览器会先发送一个OPTIONS请求,后端服务器需要正确处理该请求,并返回带有正确CORS响应头部的响应。如果在预检请求中出现CORS错误,可能是因为服务器未正确处理OPTIONS请求。 3. 带身份凭证请求(Request with Credentials)错误:当XHR请求设置了withCredentials为true时,代表允许跨域请求携带身份凭证(如cookie)。在这种情况下,跨域请求的服务器需要设置允许携带身份凭证的响应头部,如Access-Control-Allow-Credentials。如果未正确设置,会导致CORS错误。 为了解决CORS错误,可以采取以下措施: 1. 在后端服务器中正确设置CORS响应头部,包括Access-Control-Allow-Origin、Access-Control-Allow-Methods、Access-Control-Allow-Headers等。 2. 如果出现预检请求错误,需要在后端服务器中正确处理OPTIONS请求,并返回带有正确CORS响应头部的响应。 3. 如果需要跨域请求携带身份凭证,需要在后端服务器中设置Access-Control-Allow-Credentials为true,并在前端请求中设置withCredentials为true。 总的来说,解决CORS错误需要在前端和后端共同进行配置和处理。前端通过设置XHR请求的头部字段和withCredentials属性,后端通过设置CORS响应头部来实现跨域请求的安全和成功。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值