前后端项目分离解决cors错误的方法详解

 更新时间:2023年02月15日 11:27:32   作者:ych_0901  
随着前后端分离技术的越来越盛行,跨域问题也逐渐凸显了出来,下面这篇文章主要给大家介绍了关于前后端项目分离解决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错误内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MVC页面之间参数传递实现过程图解

    MVC页面之间参数传递实现过程图解

    这篇文章主要介绍了MVC页面之间参数传递实现过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • request如何获取body的json数据

    request如何获取body的json数据

    这篇文章主要介绍了request如何获取body的json数据操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • 浅谈JVM中的JOL

    浅谈JVM中的JOL

    我们天天都在使用java来new对象,但估计很少有人知道new出来的对象到底长的什么样子?对于普通的java程序员来说,可能从来没有考虑过java中对象的问题,不懂这些也可以写好代码。今天,给大家介绍一款工具JOL,可以满足大家对java对象的所有想象。
    2021-06-06
  • SpringBoot动态定时功能实现方案详解

    SpringBoot动态定时功能实现方案详解

    在SpringBoot项目中简单使用定时任务,不过由于要借助cron表达式且都提前定义好放在配置文件里,不能在项目运行中动态修改任务执行时间,实在不太灵活。现在我们就来实现可以动态修改cron表达式的定时任务,感兴趣的可以了解一下
    2022-11-11
  • Java根据key获取枚举值的操作方法

    Java根据key获取枚举值的操作方法

    枚举(enum)算一种“语法糖”,是指一个经过排序的、被打包成一个单一实体的项列表,一个枚举的实例可以使用枚举项列表中任意单一项的值,本文给大家介绍了Java 如何快速根据 key 获取枚举的值,需要的朋友可以参考下
    2024-07-07
  • idea构建web项目的超级详细教程

    idea构建web项目的超级详细教程

    好多朋友在使用IDEA创建项目时,总会碰到一些小问题,下面这篇文章主要给大家介绍了关于idea构建web项目的超级详细教程,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • Spring MVC 扩展和 SSM 框架整合步骤详解

    Spring MVC 扩展和 SSM 框架整合步骤详解

    在前端页面后后台交互的过程中,需要一种格式清晰、高效且两端都可以轻松使用的数据格式做交互的媒介,JSON正可以满足这一需求,下面学习使用Spring MVC 框架处理JSON数据,感兴趣的朋友一起看看吧
    2024-08-08
  • 多个java泛型示例分享

    多个java泛型示例分享

    这篇文章主要介绍了多个java泛型示例,需要的朋友可以参考下
    2014-04-04
  • Java 多线程之间共享数据

    Java 多线程之间共享数据

    这篇文章主要介绍了Java 多线程之间共享数据,围绕Java 多线程之间共享数据展开文章内容线程范围的共享变量、使用Map实现线程范围内数据的共享、ThreadLocal实现线程范围内数据的共享,需要的朋友可以参考一下
    2021-10-10
  • 再也不用怕! 让你彻底搞明白Java内存分布

    再也不用怕! 让你彻底搞明白Java内存分布

    做Java的大都没有c++ 的那种分配内存的烦恼,因为Java 帮我们管理内存,但是这并不代表我们不需要了解Java的内存结构,因为线上经常出现内存的问题,今天聊一下内存的问题,需要的朋友可以参考下
    2021-06-06

最新评论