欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 旅游 > Spring MVC 逻辑视图(JSP、Thymeleaf、FreeMarker)与非逻辑视图(JSON、Excel、PDF、XML)详解及示例

Spring MVC 逻辑视图(JSP、Thymeleaf、FreeMarker)与非逻辑视图(JSON、Excel、PDF、XML)详解及示例

2025/4/23 0:23:55 来源:https://blog.csdn.net/zp357252539/article/details/147066976  浏览:    关键词:Spring MVC 逻辑视图(JSP、Thymeleaf、FreeMarker)与非逻辑视图(JSON、Excel、PDF、XML)详解及示例

Spring MVC 逻辑视图与非逻辑视图详解及示例


一、逻辑视图与非逻辑视图的定义
类型定义
逻辑视图通过视图解析器(ViewResolver)将逻辑名称(如 success)映射到具体视图实现。
非逻辑视图直接返回具体视图对象(如 JsonView),或通过注解/方法直接生成响应,无需解析器。

二、逻辑视图与非逻辑视图的接口类型
类型接口示例
逻辑视图JSP、Thymeleaf、FreeMarker(模板引擎生成HTML)
非逻辑视图JSON(MappingJackson2JsonView)、Excel(ExcelView)、PDF(PdfView)、XML等

三、逻辑视图与非逻辑视图的对比
维度逻辑视图非逻辑视图
视图解析需要配置视图解析器(如 ThymeleafViewResolver无需解析器,直接返回视图对象或通过注解(如 @ResponseBody
响应格式HTML(模板引擎渲染)JSON、Excel、PDF、XML 等特定格式
解耦性控制器与视图解耦,通过名称间接关联控制器直接绑定视图实现,耦合度较高
配置复杂度需配置解析器和模板引擎简单(如直接使用注解或自定义View类)
典型场景前端页面渲染(如网页跳转)API返回数据、文件下载、特殊格式输出

四、代码示例

1. 逻辑视图示例

(1)JSP 示例

// 配置JSP视图解析器(在Spring配置类中)
@Configuration
public class WebConfig implements WebMvcConfigurer {@Beanpublic ViewResolver viewResolver() {InternalResourceViewResolver resolver = new InternalResourceViewResolver();resolver.setPrefix("/WEB-INF/views/"); // JSP文件存放路径resolver.setSuffix(".jsp");            // 文件后缀return resolver;}
}// 控制器方法
@Controller
public class UserController {@GetMapping("/user/jsp")public String showUserJsp(Model model) {model.addAttribute("userName", "John Doe");return "userProfile"; // 返回逻辑视图名,对应userProfile.jsp}
}// userProfile.jsp 文件(存放于 /WEB-INF/views/)
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>User Profile</title></head>
<body><h1>User Name: ${userName}</h1>
</body>
</html>

(2)Thymeleaf 示例

// 配置Thymeleaf视图解析器(在Spring配置类中)
@Configuration
public class WebConfig implements WebMvcConfigurer {@Beanpublic SpringTemplateEngine templateEngine() {SpringTemplateEngine engine = new SpringTemplateEngine();engine.setTemplateResolver(templateResolver());return engine;}@Beanpublic SpringResourceTemplateResolver templateResolver() {SpringResourceTemplateResolver resolver = new SpringResourceTemplateResolver();resolver.setPrefix("classpath:/templates/");resolver.setSuffix(".html");return resolver;}@Beanpublic ThymeleafViewResolver viewResolver() {ThymeleafViewResolver resolver = new ThymeleafViewResolver();resolver.setTemplateEngine(templateEngine());return resolver;}
}// 控制器方法
@Controller
public class UserController {@GetMapping("/user/thymeleaf")public String showUserThymeleaf(Model model) {model.addAttribute("user", new User("John", "Doe"));return "userProfile"; // 对应userProfile.html模板}
}// userProfile.html(存放于 templates/)
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head><title>User Profile</title></head>
<body><h1 th:text="${user.firstName} + ' ' + ${user.lastName}"></h1>
</body>
</html>

2. 非逻辑视图示例

(1)JSON 示例

// 直接返回JSON(使用@ResponseBody注解)
@RestController
public class UserController {@GetMapping("/user/json")public User getUserJson() {return new User("John", "Doe"); // 自动序列化为JSON}
}// 或通过ModelAndView返回JSON视图
@Controller
public class UserController {@GetMapping("/user/json-view")public ModelAndView getUserJsonView() {ModelAndView modelAndView = new ModelAndView();modelAndView.setView(new MappingJackson2JsonView());modelAndView.addObject("user", new User("John", "Doe"));return modelAndView;}
}

(2)Excel 示例(使用Apache POI)

// 自定义Excel视图类
public class ExcelView extends AbstractView {@Overrideprotected void renderMergedOutputModel(Map<String, Object> model,HttpServletRequest request,HttpServletResponse response) throws Exception {response.setContentType("application/vnd.ms-excel");response.setHeader("Content-Disposition", "attachment; filename=users.xls");HSSFWorkbook workbook = new HSSFWorkbook();HSSFSheet sheet = workbook.createSheet("Users");HSSFRow headerRow = sheet.createRow(0);headerRow.createCell(0).setCellValue("First Name");headerRow.createCell(1).setCellValue("Last Name");List<User> users = (List<User>) model.get("users");for (int i = 0; i < users.size(); i++) {HSSFRow row = sheet.createRow(i + 1);row.createCell(0).setCellValue(users.get(i).getFirstName());row.createCell(1).setCellValue(users.get(i).getLastName());}workbook.write(response.getOutputStream());workbook.close();}
}// 控制器方法
@Controller
public class ExcelController {@GetMapping("/generate/excel")public ModelAndView generateExcel() {ModelAndView modelAndView = new ModelAndView();modelAndView.setView(new ExcelView());modelAndView.addObject("users", Arrays.asList(new User("John", "Doe"),new User("Jane", "Smith")));return modelAndView;}
}

(3)PDF 示例(使用iText)

// 自定义PDF视图类
public class PdfView extends AbstractView {@Overrideprotected void renderMergedOutputModel(Map<String, Object> model,HttpServletRequest request,HttpServletResponse response) throws Exception {response.setContentType("application/pdf");response.setHeader("Content-Disposition", "inline; filename=document.pdf");Document document = new Document();PdfWriter.getInstance(document, response.getOutputStream());document.open();document.add(new Paragraph("Hello PDF!"));document.close();}
}// 控制器方法
@Controller
public class PdfController {@GetMapping("/generate/pdf")public ModelAndView generatePdf() {ModelAndView modelAndView = new ModelAndView();modelAndView.setView(new PdfView());return modelAndView;}
}

五、总结表格
类型接口示例响应格式是否需要解析器配置方式典型场景
逻辑视图JSP、ThymeleafHTML配置ViewResolver前端页面渲染
非逻辑视图JSON、Excel、PDFJSON、XLS、PDF直接实例化View或使用注解API响应、文件下载、特殊格式

关键区别
  • 逻辑视图:依赖模板引擎生成HTML,需配置视图解析器,适合前后端分离场景。
  • 非逻辑视图:直接返回数据或文件,无需解析器,适合API、文件导出等场景,配置更灵活。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词