uniapp调用java接口 跨域问题

前言

之前在Windows10本地 调试一个旧项目,手机移动端用的是Uni-app,vue的版本是v2。后端是java spring-boot。运行手机移动端的首页请求后台接口老是提示错误信息。

错误信息如下:

Access to XMLHttpRequest at 'http://localhost:8080/api/industry/getIndustryList' from origin 'http://localhost:8081' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.

翻译后 :

从源"http://localhost:8081"访问"http://localhost:8080/api/industry/getIndustryList"的XMLHttpRequest已被CORS策略阻止:对预检请求的响应未通过访问控制检查:请求的资源未包含"Access-Control-Allow-Origin"标头。

解决问题:

1,在uni-app项目 修改

javascript 复制代码
    "h5" : {
        "title" : "",
        "domain" : "",
        "devServer" : {
            "proxy" : {
			   "/api/": {
					 "target":"http://localhost:8080/api/",
					 "changeOrigin": true,
					 "pathRewrite": {"^/api": ""}
				}
            }
        }
    },

2,java端修改继承WebMvcConfigurer的重写addCorsMappings()方法代码

java 复制代码
public class InterceptorConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**") // 对所有路径应用
            .allowedOrigins("http://localhost:8081") // 允许的来源,根据实际情况修改
            .allowedMethods("GET", "POST", "PUT", "DELETE") // 允许的方法
            .allowedHeaders("*") // 允许的头部
            .allowCredentials(true) // 是否发送Cookie
            .maxAge(3600); // 预检请求的有效期(秒)
    }
}
相关推荐
你的眼睛會笑7 分钟前
uniapp 鸿蒙元服务 真机调试流程指南
华为·uni-app·harmonyos
开始了码10 分钟前
关于qt运行程序点击几下未响应的原因
开发语言·qt
QT 小鲜肉11 分钟前
【QT/C++】Qt样式设置之CSS知识(系统性概括)
linux·开发语言·css·c++·笔记·qt
洛克希德马丁17 分钟前
Qt配置安卓开发环境
android·开发语言·qt
我要升天!18 分钟前
QT-- 理解项目文件
开发语言·数据库·qt
jonyleek19 分钟前
【JVS更新日志】低代码、APS排产、物联网、企业计划11.12更新说明!
java·物联网·低代码·前端框架·团队开发
keke_俩个科32 分钟前
实战派 JMeter 指南:核心功能、并发压测实操与常见问题解决方案
java·jmeter·spring·spring cloud·tomcat
青鱼入云44 分钟前
IDEA源码阅读神器-Diagram工具
java·ide·intellij-idea
占疏1 小时前
访问日志查询功能
java·服务器·flask
星光一影1 小时前
Java版社交系统/聊天系统/im/即时通信/社交通讯
java·spring boot·mysql·交友