目录
一、页面跳转
<https://blog.csdn.net/qq_41647999/article/details/83788265#%E4%B8%80%E3%80%81%E9%A1%B5%E9%9D%A2%E8%B7%B3%E8%BD%AC>
二、情况说明
<https://blog.csdn.net/qq_41647999/article/details/83788265#%E4%BA%8C%E3%80%81%E6%83%85%E5%86%B5%E8%AF%B4%E6%98%8E>
三、 问题解决方案
<https://blog.csdn.net/qq_41647999/article/details/83788265#%E4%B8%89%E3%80%81%20%E9%97%AE%E9%A2%98%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88>
1、 引入thymeleaf的依赖包
<https://blog.csdn.net/qq_41647999/article/details/83788265#1%E3%80%81%20%E5%BC%95%E5%85%A5thymeleaf%E7%9A%84%E4%BE%9D%E8%B5%96%E5%8C%85>
2、 项目路径
<https://blog.csdn.net/qq_41647999/article/details/83788265#2%E3%80%81%20%E9%A1%B9%E7%9B%AE%E8%B7%AF%E5%BE%84>
注意
<https://blog.csdn.net/qq_41647999/article/details/83788265#%E6%B3%A8%E6%84%8F>
(1) 页面引用外部静态资源的方式
<https://blog.csdn.net/qq_41647999/article/details/83788265#%EF%BC%881%EF%BC%89%20%E9%A1%B5%E9%9D%A2%E5%BC%95%E7%94%A8%E5%A4%96%E9%83%A8%E9%9D%99%E6%80%81%E8%B5%84%E6%BA%90%E7%9A%84%E6%96%B9%E5%BC%8F>
(2) 核心解决方案
<https://blog.csdn.net/qq_41647999/article/details/83788265#%EF%BC%882%EF%BC%89%20%E6%A0%B8%E5%BF%83%E8%A7%A3%E5%86%B3%E6%96%B9%E6%A1%88>
一、页面跳转
如果你还没有实现页面跳转,推荐阅读:SpringBoot跳转渲染页面(详解)
<https://blog.csdn.net/qq_41647999/article/details/83690696>
二、情况说明
SpringBoot整合thymeleaf实现的页面跳转,该页面引用外部css、js等静态资源。
如果你发现跳转页面成功之后出现下图情况,说明我等的就是你!我为了解决这个问题阅读了很多博客,这个问题我整整卡了一天的时间,终于有幸看到了一篇文章解决了我的问题,于是将解决方案总结了。
在浏览器中按了F12之后发现,根本就没有成功访问静态资源!但是你发现你在编辑器里面按着Ctrl用鼠标点的时候静态资源都能够访问。报些错误真的是花里胡哨的~
No mapping found for HTTP request with URI(静态资源路径)
三、 问题解决方案
我一步一步的讲,如果您已经完成了某些步骤,可以直接跳过。
1、 引入thymeleaf的依赖包
在pom.xml的文件中加入
<!-- 引入thymeleaf依赖包 --> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency>
2、 项目路径
TestController里面写的是页面的跳转代码,跳转的是后台的登录界面。我还是把代码拿出来你参考下吧。
(1) 注意
SpringBoot会默认从下面的目录去读取:
(1) static里面放所有的静态资源。
(2) templates里面放页面,这里是templates -> admin,我是放在admin这个文件里面的。
TestController.java
package com.demo.demo.Controller; import
org.springframework.stereotype.Controller; import
org.springframework.web.bind.annotation.RequestMapping; import
org.springframework.web.bind.annotation.RequestMethod; @Controller public class
TestController { @RequestMapping(value = "/admin",method = RequestMethod.GET)
public String index(){ //后缀为.html的文件名 return "admin/index"; } }
(2) 页面引用外部静态资源的方式
注意我这里的静态资源的路径,虽然编辑器找不到资源,但是页面是能够正确访问的。
(3) 核心解决方案
请看我的Controller里面有一个UsingStaticController。
你新建一个Java class,代码如下:
package com.demo.demo.Controller; import
org.springframework.context.annotation.Configuration; import
org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import
org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;
@Configuration public class UsingStaticController extends
WebMvcConfigurationSupport { public void
addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/static/**").addResourceLocations("classpath:/static/");
} }
再次重新运行项目,问题就解决了。
到此处,我以为我的问题解决了,其实登陆(index.html)成功之后是不能成功跳转到主页(admin.html)的。
如果你也遇到了相同的情况,请继续阅读以下解决方案。
看一下我是如何跳转主页的
index.html
这个涉及到thymeleaf表单提交的问题。因为这个页面引用的很多外部样式无法实现页面效果,所以只选取了关键代码。
th:action="@{/user}" 这个是提交给后台的URL地址,请看下方的Controller的代码。
<form th:action="@{/user}" method="post"> <div class="row cl"> <div
class="formControls col-xs-8"> <inputtype="text" placeholder="账户"> </div>
</div> <div class="row cl"> <div class="formControls col-xs-8"> <input
type="password" placeholder="密码"> </div> </div> <div class="row cl"> <input
type="submit" value=" 登 录 "> <input
type="reset"value=" 取 消 "> </div> </form>
PagesController.java代码
package com.demo.demo.Controller; import com.demo.demo.Model.Message; import
org.springframework.stereotype.Controller; import
org.springframework.web.bind.annotation.ModelAttribute; import
org.springframework.web.bind.annotation.RequestMapping; import
org.springframework.web.bind.annotation.RequestMethod; @Controller public class
PagesController { @RequestMapping(value = "/admin",method = RequestMethod.GET)
public String index(){ //后缀为.html的文件名 return "admin/index"; } //响应表单上的POST请求
@RequestMapping(value = "/user",method = RequestMethod.POST) public String
save(@ModelAttribute(value="message") Message message) { return "admin/admin";
} }
成功跳转到菜单之后,左侧边栏的li 大家应该都知道这都是html的页面。
在我的admin目录(目录截图请往上翻)里面有几个图表html:
这是因为,点击左侧边栏之后找不到页面造成的,也就是说你发送的请求没有得到响应。解决方案如下PagesController的代码更改。
package com.demo.demo.Controller; import com.demo.demo.Model.Message; import
org.springframework.stereotype.Controller; import
org.springframework.web.bind.annotation.ModelAttribute; import
org.springframework.web.bind.annotation.RequestMapping; import
org.springframework.web.bind.annotation.RequestMethod; @Controller public class
PagesController { @RequestMapping(value = "/admin",method = RequestMethod.GET)
public String index(){ //后缀为.html的文件名 return "admin/index"; }
@RequestMapping(value = "/charts-1",method = RequestMethod.GET) public String
charts_1(){ return "admin/charts-1"; } @RequestMapping(value =
"/charts-2",method = RequestMethod.GET) public String charts_2(){ return
"admin/charts-2"; } @RequestMapping(value = "/charts-3",method =
RequestMethod.GET) public String charts_3(){ return "admin/charts-3"; }
@RequestMapping(value = "/charts-4",method = RequestMethod.GET) public String
charts_4(){ return "admin/charts-4"; } @RequestMapping(value =
"/charts-5",method = RequestMethod.GET) public String charts_5(){ return
"admin/charts-5"; } @RequestMapping(value = "/charts-6",method =
RequestMethod.GET) public String charts_6(){ return "admin/charts-6"; }
@RequestMapping(value = "/charts-7",method = RequestMethod.GET) public String
charts_7(){ return "admin/charts-7"; } @RequestMapping(value =
"/echarts",method = RequestMethod.GET) public String echarts(){ return
"admin/echarts"; } @RequestMapping(value = "/admin-role",method =
RequestMethod.GET) public String admin_role(){ return "admin/admin-role"; }
@RequestMapping(value = "/user",method = RequestMethod.POST) public String
save(@ModelAttribute(value="message") Message message) { return "admin/admin";
} }
左侧边栏的页面显示的问题也就解决了!
热门工具 换一换