在我们开发Web应用的时候,需要引用大量的js、css、图片等静态资源。
默认配置:Spring Boot默认提供静态资源目录位置需置于classpath下,目录名需符合如下规则:
/static
/public
/resources
/META-INF/resources
举例:我们可以在src/main/resources/static/目录下创建test.jpg,在该位置放置一个图片文件。启动程序后,尝试访问http://localhost:8080/test.jpg。如能显示图片,配置成功。
渲染Web页面
在之前的示例中,我们都是通过@RestController来处理请求,所以返回的内容为json对象。那么如果需要渲染html页面的时候,要如何实现呢?
模板引擎
在动态HTML实现上Spring Boot依然可以完美胜任,并且提供了多种模板引擎的默认配置支持,所以在推荐的模板引擎下,我们可以很快的上手开发动态网站。
Spring Boot提供了默认配置的模板引擎主要有以下几种:
• Thymeleaf
• FreeMarker
• Velocity
• Groovy
• Mustache
Spring Boot建议使用这些模板引擎,避免使用JSP,若一定要使用JSP将无法实现Spring Boot的多种特性,具体可见后文:支持JSP的配置
当你使用上述模板引擎中的任何一个,它们默认的模板配置路径为:src/main/resources/templates。当然也可以修改这个路径,具体如何修改,可在后续各模板引擎的配置属性中查询并修改。
org.springframework.boot
spring-boot-starter-freemarker
在src/main/resources/templates文件夹创建index.ftl,后缀为*.ftl
@Controller
public class IndexController {
@GetMapping("indexTest")
public String index(Map map ){
map.put("name","zhangsan");
return "index";
}
}
Title
这是 springboot--web演示!
name 的值为${name}
Index2Controller:
@Controller
public class Index2Controller {
@GetMapping("index2")
public String index(Map result ){
result.put("name", "yushengjun");
result.put("sex", "0");
List listResult = new ArrayList();
listResult.add("zhangsan");
listResult.add("lisi");
listResult.add("itmayiedu");
result.put("listResult", listResult);
return "index2";
}
}
创建index2.ftl
Title
${name}
<#if sex=="1">
男
<#elseif sex=="2">
女
<#else>
其他
#if>
<#list listResult as user>
${user}
#list>
新建application.properties文件
FREEMARKER (FreeMarkerAutoConfiguration)
spring.freemarker.allow-request-override=false
spring.freemarker.cache=true
spring.freemarker.check-template-location=true
spring.freemarker.charset=UTF-8
spring.freemarker.content-type=text/html
spring.freemarker.expose-request-attributes=false
spring.freemarker.expose-session-attributes=false
spring.freemarker.expose-spring-macro-helpers=false
#spring.freemarker.prefix=
#spring.freemarker.request-context-attribute=
#spring.freemarker.settings.*=
spring.freemarker.suffix=.ftl
spring.freemarker.template-loader-path=classpath:/templates/
#comma-separated list
#spring.freemarker.view-names= # whitelist of view names that can be resolved
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-tomcat
org.apache.tomcat.embed
tomcat-embed-jasper
spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
#关闭默认模板引擎
spring.thymeleaf.cache=false
spring.thymeleaf.enabled=false
@Controller
public class JspTestController {
@GetMapping("/jsp")
public String index( ){
System.out.println("jspTest ========================");
return "jspTest";
}
}
注意:创建SpringBoot整合JSP,一定要为war类型,否则会找不到页面.
不要把JSP页面存放在resources// jsp 不能被访问到;springboot2.0+ 需要部署在tomcat8.5+ 版本;
@ControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(RuntimeException.class)
@ResponseBody
public Map exceptionHandler() {
Map map = new HashMap();
map.put("errorCode", "101");
map.put("errorMsg", "系統错误!");
return map;
}
}
源码下载: https://github.com/ruiace/springboot-web.git