Spring MVC 响应机制综合实践:页面、数据、JSON 与响应配置

Spring MVC 响应机制的核心方式

返回视图(页面渲染)

通过返回视图名称(如 return "home"),配合视图解析器(InternalResourceViewResolver)定位到 /WEB-INF/views/home.jsp 等具体页面。需在配置中定义视图前缀和后缀:

java 复制代码
@Bean
public ViewResolver viewResolver() {
    InternalResourceViewResolver resolver = new InternalResourceViewResolver();
    resolver.setPrefix("/WEB-INF/views/");
    resolver.setSuffix(".jsp");
    return resolver;
}

返回纯文本或HTML

使用 @ResponseBody 注解直接返回字符串内容,适用于简单文本或HTML片段:

java 复制代码
@GetMapping("/text")
@ResponseBody
public String rawText() {
    return "<h1>Hello World</h1>";
}

JSON 响应处理

自动序列化对象为JSON

结合 @RestController@ResponseBody,Spring 默认使用 Jackson 将对象序列化为 JSON:

java 复制代码
@GetMapping("/user")
public User getUser() {
    return new User("Alice", 25);
}

需添加 Jackson 依赖(如 spring-boot-starter-json)。

定制JSON字段

通过 @JsonIgnore 忽略字段,@JsonProperty 重命名字段:

java 复制代码
public class User {
    @JsonProperty("username")
    private String name;
    
    @JsonIgnore
    private String password;
}

响应头与状态码控制

手动设置状态码

使用 ResponseEntity 自定义状态码和响应头:

java 复制代码
@GetMapping("/custom")
public ResponseEntity<String> customResponse() {
    HttpHeaders headers = new HttpHeaders();
    headers.add("X-Custom-Header", "value");
    return new ResponseEntity<>("Custom Body", headers, HttpStatus.CREATED);
}

重定向与转发

通过 redirect: 前缀实现重定向,或返回 ModelAndView 进行转发:

java 复制代码
@GetMapping("/redirect")
public String redirect() {
    return "redirect:/new-url";
}

全局响应配置

统一响应格式

使用 @ControllerAdvice 定义全局响应封装:

java 复制代码
@ControllerAdvice
public class GlobalResponseHandler implements ResponseBodyAdvice<Object> {
    @Override
    public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) {
        return true;
    }

    @Override
    public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType, 
                                  Class<? extends HttpMessageConverter<?>> selectedConverterType, 
                                  ServerHttpRequest request, ServerHttpResponse response) {
        return new ResponseWrapper<>(200, "success", body);
    }
}

CORS 跨域配置

在配置类中全局启用 CORS:

java 复制代码
@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/api/**")
                .allowedOrigins("*")
                .allowedMethods("GET", "POST");
    }
}

异常处理与错误响应

统一异常处理

通过 @ExceptionHandler 捕获异常并返回结构化错误信息:

java 复制代码
@ControllerAdvice
public class GlobalExceptionHandler {
    @ExceptionHandler(Exception.class)
    public ResponseEntity<ErrorResponse> handleException(Exception ex) {
        ErrorResponse error = new ErrorResponse(500, ex.getMessage());
        return ResponseEntity.status(500).body(error);
    }
}

自定义错误页面

配置 ErrorViewResolver 或定义 /error 映射:

java 复制代码
@Controller
public class ErrorController implements ErrorController {
    @RequestMapping("/error")
    public String handleError(HttpServletRequest request) {
        Integer status = (Integer) request.getAttribute("javax.servlet.error.status_code");
        return status == 404 ? "error-404" : "error-general";
    }
}
相关推荐
计算机学姐2 小时前
基于SpringBoot的自习室座位预定系统【预约选座+日期时间段+协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·后端·spring·信息可视化·tomcat
Thomas_YXQ2 小时前
Unity3D中提升AssetBundle加载速度的详细指南
java·spring boot·spring·unity·性能优化·游戏引擎·游戏开发
仙俊红3 小时前
Spring Cloud 核心组件部署方式速查表
后端·spring·spring cloud
梵高的代码色盘3 小时前
Spring AI 整合大模型:Prompt 提示词的标准化设计与最佳实践
人工智能·spring·prompt
静小谢3 小时前
前端mock假数据工具JSON Server使用笔记
前端·笔记·json
今天多喝热水4 小时前
SpEL(Spring Expression Language) 表达式
java·后端·spring
程序员乐只5 小时前
基于Python+Django+SSM热门旅游景点推荐系统(源码+LW+调试文档+讲解等)/热门旅游地推荐平台/旅游景点推荐软件/热门景点推荐系统/旅游推荐系统/旅游景点热门推荐
spring boot·spring·tomcat·hibernate·java-zookeeper·guava·java-consul
空空kkk5 小时前
SpringBoot整合Thymeleaf
java·spring boot·spring
辰阳星宇5 小时前
python代码修复字符串json数据格式问题,并将其按照字典形式读取
windows·python·json