目录
静态资源访问
1.springboot访问静态资源的几种方式
(1)在src/main/resources/目录下创建
static文件夹
(2)在src/main/resources/目录下创建
resources文件夹
(3)在src/main/resources/目录下创建
public文件夹
(4)在src/main/resources/目录下创建
META-INF/resources文件夹
目录结构图:
举例:我们可以在src/main/resources/目录下创建static,在该位置放置一个图片文件。启动程序后,尝试访问http://localhost:8080/x.jpg。如能显示图片,配置成功。
全局捕获异常
springboot可以创建一个全局的异常处理类,将所有出现的异常拦截
@ExceptionHandler 表示拦截异常
@ControllerAdvice 是 controller 的一个辅助类,最常用的就是作为全局异常处理的切面类
@ControllerAdvice 可以指定扫描范围
@ControllerAdvice 约定了几种可行的返回值,如果是直接返回 model 类的话,需要使用 @ResponseBody 进行 json 转换
返回 String,表示跳到某个 view
返回 modelAndView
返回 model + @ResponseBody
异常处理代码类:
/**
* 全局异常处理
* @ExceptionHandler 表示拦截异常
*/
@ControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(RuntimeException.class)//要拦截的异常的类型--系统运行异常
@ResponseBody
public Map<String,Object> exceptionHandler(){
Map<String,Object> map=new HashMap<String,Object>();
map.put("errorcode","zero");
map.put("msg","系统错误!");
return map;
}
@ExceptionHandler(NullPointerException.class)
@ResponseBody
public Map<String,Object> nullPointExceptionHandler(){
Map<String,Object> map=new HashMap<String,Object>();
map.put("errorcode","NULL");
map.put("msg","空指针异常!");
return map;
}
}
测试代码类:
@RestController
public class HelloController {
@RequestMapping("hello")
String hello() {
Object a=null;
a.equals("null");
int i=1/0;
return "Hello World!";
}
}
效果如图:
渲染web页面
渲染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。当然也可以修改这个路径,具体如何修改,可在后续各模板引擎的配置属性中查询并修改。
使用Freemarker模版引擎渲染web视图
依赖引入:
<!-- 引入freeMarker的依赖包. -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
在src/main/resources/创建一个templates文件夹,然后创建index.ftl,注意freemarker模板引擎对应的文件后缀为*.ftl,如图:
前端代码:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8" />
<title></title>
</head>
<body>
${name}
</body>
</html>
后端代码:
@Controller//注意使用的是@Controller,使用@RestController会返回json
public class PageController {
@RequestMapping("index.html")
public String index(Map<String, Object> map){
map.put("name","springboot模板引擎测试");
return "index";
}
}
效果图: