Java开发-后端请求成功,前端显示失败

文章目录

    • 报错
    • 解决方案
      • [1. 后端未配置跨域支持](#1. 后端未配置跨域支持)
      • [2. 后端响应的 Content-Type 或 CORS 配置问题](#2. 后端响应的 Content-Type 或 CORS 配置问题)
      • [3. 前端 request 配置问题](#3. 前端 request 配置问题)
      • [4. 浏览器缓存或代理问题](#4. 浏览器缓存或代理问题)
      • [5. 后端端口未被正确映射](#5. 后端端口未被正确映射)

报错

如下图,后端显示请求成功,前端显示失败

解决方案

1. 后端未配置跨域支持

默认情况下,不同源(域名、端口、协议)的请求会受到浏览器的跨域限制(CORS)。前端 http://localhost:8080 和后端 http://localhost:8090 被视为不同源,因此会导致请求被阻止。

解决方法:在后端添加跨域支持

java 复制代码
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**") // 匹配所有路径
                .allowedOrigins("http://localhost:8080") // 允许前端域名
                .allowedMethods("GET", "POST", "PUT", "DELETE", "OPTIONS") // 允许的请求方法
                .allowCredentials(true) // 允许携带凭证
                .maxAge(3600); // 缓存时间
    }
}

如果项目中使用了 Spring Boot,可以直接在控制器方法上添加注解:

java 复制代码
@CrossOrigin(origins = "http://localhost:8080")
@GetMapping("/login")
public class UserController {
	public Result login(@RequestParam String username, @RequestParam String password) {
   		// 登录逻辑
    	return Result.success(1);
	}
}

2. 后端响应的 Content-Type 或 CORS 配置问题

如果后端的返回头缺少正确的内容类型或跨域响应头,浏览器也可能拒绝请求。

解决方法:确保后端返回头正确设置

java 复制代码
@GetMapping("/login")
public Result login(@RequestParam String username, @RequestParam String password, HttpServletResponse response) {
    // 设置响应头
    response.setHeader("Access-Control-Allow-Origin", "http://localhost:8080");
    response.setHeader("Access-Control-Allow-Methods", "GET, POST, OPTIONS");
    response.setHeader("Access-Control-Allow-Headers", "Content-Type, Authorization");
    response.setHeader("Access-Control-Allow-Credentials", "true");

    // 登录逻辑
    int result = userService.login(username, password);
    return Result.success(result);
}

3. 前端 request 配置问题

检查前端是否正确发起了请求,包括 baseURL 是否正确,是否携带了其他额外的头。

确保前端 axios 配置正确

javascript 复制代码
import axios from "axios";

const request = axios.create({
  baseURL: "http://localhost:8090", // 后端服务地址
  timeout: 5000, // 超时时间
  headers: {
    "Content-Type": "application/json", // 确保类型正确
  },
});

export default request;

调用接口时,应传递 params 而不是 data,因为是 GET 请求:

javascript 复制代码
request({
  method: "get",
  url: "/login",
  params: {
    username: this.user.username,
    password: this.user.password,
  },
})
  .then((resp) => {
    console.log(resp.data);
  })
  .catch((error) => {
    console.error(error);
  });

4. 浏览器缓存或代理问题

某些情况下,浏览器缓存或代理工具可能导致请求异常。

解决方法:

解决方法:

  • 清除浏览器缓存并重试。
  • 检查是否有代理工具拦截了请求(如 Charles 或 Fiddler)。
  • 在请求中加上时间戳避免缓存问题:
javascript 复制代码
params: {
  username: this.user.username,
  password: this.user.password,
  _t: new Date().getTime(), // 避免缓存
}

5. 后端端口未被正确映射

如果你运行的后端服务(如 Spring Boot)监听的端口未正确绑定到网络,前端可能无法访问。

解决方法:

  • 确认后端服务启动成功且端口未被占用。
  • 使用工具(如 Postman)单独测试后端 API,确认后端可用。
相关推荐
超级大只老咪5 小时前
数组相邻元素比较的循环条件(Java竞赛考点)
java
小浣熊熊熊熊熊熊熊丶5 小时前
《Effective Java》第25条:限制源文件为单个顶级类
java·开发语言·effective java
毕设源码-钟学长5 小时前
【开题答辩全过程】以 公交管理系统为例,包含答辩的问题和答案
java·eclipse
啃火龙果的兔子5 小时前
JDK 安装配置
java·开发语言
星哥说事5 小时前
应用程序监控:Java 与 Web 应用的实践
java·开发语言
派大鑫wink5 小时前
【JAVA学习日志】SpringBoot 参数配置:从基础到实战,解锁灵活配置新姿势
java·spring boot·后端
程序员爱钓鱼6 小时前
Node.js 编程实战:文件读写操作
前端·后端·node.js
xUxIAOrUIII6 小时前
【Spring Boot】控制器Controller方法
java·spring boot·后端
PineappleCoder6 小时前
工程化必备!SVG 雪碧图的最佳实践:ID 引用 + 缓存友好,无需手动算坐标
前端·性能优化
Dolphin_Home6 小时前
从理论到实战:图结构在仓库关联业务中的落地(小白→中级,附完整代码)
java·spring boot·后端·spring cloud·database·广度优先·图搜索算法