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); // 预检请求的有效期(秒)
    }
}
相关推荐
dyj09520 小时前
【Devops-Jenkins自动将Java Maven工程编译成jar、并打成Docker镜像,并上传Harbor】
java·jenkins·devops
std787921 小时前
Rust 与 Go – 比较以及每个如何满足您的需求
开发语言·golang·rust
gordon~921 小时前
Spring 的bean是安全的吗
java·安全·spring·bean
报错小能手21 小时前
python(入门)map内置函数及import模块导入,as别名
开发语言·人工智能·python
梵得儿SHI21 小时前
Java 反射机制实战:对象属性复制与私有方法调用全解析
java·开发语言·java反射机制的实际应用·对象属性复制·反射调用私有方法·私有字段·类型兼容性和敏感字段忽略
sulikey21 小时前
C++的STL:深入理解 C++ 的 std::initializer_list
开发语言·c++·stl·list·initializerlist·c++标准库
coldriversnow21 小时前
uni-app从后端返回的富文本中的视频截取一帧为封面
uni-app
带刺的坐椅21 小时前
LangChain4j 比 SolonAI 强在哪?弱在哪?
java·ai·langchain·solon·mcp
liu****21 小时前
19.map和set的封装
开发语言·数据结构·c++·算法
孤廖21 小时前
C++ 模板再升级:非类型参数、特化技巧(含全特化与偏特化)、分离编译破解
linux·服务器·开发语言·c++·人工智能·后端·深度学习