Spring所支持的Resolver 非常多,但是我们最为常用的还是 InternalResourceViewResolver 。常规就是贴出一下InternalResourceViewResolver的常用配置:
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="/WEB-INF/views/" p:suffix=".jsp" p:order="99" ></bean>
这里我说一下其余的两个resolver
BeanNameViewResolver 这个resolver会找到相应的bean最为view这个非常有用,我们会使用这个resolver处理一些导出EXCEL和导出PDF的view,当然也有人使用这个来做JSON和XML View的视图解析,但是一般情况下我都是采用HttpMessageConvert做JSON和XML的输出。
CommonsMultipartResolver 这个用于文件上传之用。
其他还有什么国际化的、解析为URL文件的等等,这里就不再细说。下面我会做一个excel导出 和文件上传功能,来感受BeanNameViewResolver和CommonsMultipartResolver的作用。
EXCEL导出
Excel导出在SpringMVC非常简单,我们需要实现一个AbstractXlsxView的类,作为相应的View。然后通过BeanNameViewResolver 获得并使用这个View的输出进行响应。
编写一个导出用户数据excel的view
public class UserListExcelView extends AbstractXlsxView { protected void buildExcelDocument(Map<String, Object> map, Workbook workbook, HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception { httpServletResponse.setHeader(HttpHeaders.CONTENT_DISPOSITION, "inline;filename=" + new String("UserList.xlsx".getBytes(), "utf-8")); List<User> resultList = (List<User>) map.get("userList"); Sheet sheet = workbook.createSheet("UserList"); Row header = sheet.createRow(0); header.createCell(0).setCellValue(