静态资源无法访问到,并且出现警告:
WARN 37536 --- [demo] [nio-8080-exec-1] .w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.web.method.annotation.MethodArgumentTypeMismatchException: Failed to convert value of type 'java.lang.String' to required type 'java.lang.Integer'; For input string: "image.png"]
先说原因,访问静态资源http://localhost:8080/image.png被当成控制器请求了,导致出错。
下面举个例子,创建一个springboot3项目,项目结构如下
TestController.java
@Controller
public class TestController {
@GetMapping("")
public String Test1() {
return "test";
}
@GetMapping("/{id}")
public String Test2(@PathVariable("id") Integer id) {
System.out.println("处理id"+id);
return "test";
}
}
test.html
<!DOCTYPE html>
<html>
<head>
<title>title</title>
</head>
<body>
<h3>test</h3>
<img src="/image.png" alt="image">
</body>
</html>
运行时加载不出图片
在渲染的html文件中要访问静态资源image.png,这个图片资源在服务器的完整路径是localhost:8080/image.png,但是恰好控制器方法Test2处理的HTTP请求是http://localhost:8080/{id},它可以带有一个路径变量,那访问图片的请求localhost:8080/image.png就被这个控制器方法Test2给处理了(路径中的image.html被当成路径变量),然而Test2方法需要的参数是Integer类型的,"image.html"(String类型)无法被转换成Integer,那自然就报错了,图片也就无法获取到
解决方法
将image.png移到images目录下
test.html也做更改
这次可以成功访问到图片,因为现在图片路径是http://localhost:8080/images/image.png
,不会再被控制器方法Test2当成HTTP请求处理
总结就是,只要静态资源的完整路径不跟控制器方法处理的url冲突,就不会出现像上面那种静态资源请求被当成控制器请求来处理的情况了。