基于springboot1.5.9整合shiro时出现静态文件找不到的问题
开门见山吧,上午对shiro进行整合了下,因为之前使用ssm框架对shiro框架整合过,所以觉得使用springboot再次对shiro框架进行整合也是没啥问题,但最后整合完之后,使用thymeleaf模板对静态文件进行引入时,竟然出错了,然后按f12看了下错误,如下图:
一看到这种错误,给人第一感觉就是静态文件没有引入进来,所以我再点了sources检查是否引入了js文件,如下图:
这样一看,就感觉不对了,放在static下的静态文件竟然没有引入,再看下项目目录:
感觉没问题啊,然后再在login.html文件引入js的路径,按ctrl+鼠标左键试下能否进入jq文件中,试了后,可以啊,代码如下:
<script src="../static/statics/js/jquery-2.1.1.js" th:src="@{/statics/js/jquery-2.1.1.js}"></script>
而且我也是使用了thymeleaf模板方式,虽说引用路径的优先级是模板语法>html本身的引用方式,而且使用该语法,可以直接省略static文件夹路径的,当发现这些都没有问题之后,再次检查下shiroConfiguration类中对权限过滤的方式:
//配置访问权限的路径
LinkedHashMap<String , String> filterChainDefinitionMap = new LinkedHashMap<>() ;
//过滤静态文件请求
filterChainDefinitionMap.put("/static/**" , "anon") ;
//过滤访问swagger请求
filterChainDefinitionMap.put("/swagger-resources/**" , "anon") ;
filterChainDefinitionMap.put("/v2/api-docs/**" , "anon") ;
filterChainDefinitionMap.put("/webjars/**" , "anon") ;
filterChainDefinitionMap.put("/swagger-ui.html" , "anon") ;
//过滤登录请求
filterChainDefinitionMap.put("/login.html" , "anon") ;
filterChainDefinitionMap.put("/login" , "anon") ;
filterChainDefinitionMap.put("/doLogin" , "anon") ;
//过滤默认访问界面请求
filterChainDefinitionMap.put("/" , "anon") ;
//过滤注销请求
filterChainDefinitionMap.put("/logout*" , "anon") ;
//对页面访问进行拦截验证
filterChainDefinitionMap.put("/*.html" , "authc") ;
filterChainDefinitionMap.put("/*" , "authc") ;
filterChainDefinitionMap.put("/**" , "authc") ;
filterChainDefinitionMap.put("/*.*" , "authc") ;
bean.setFilterChainDefinitionMap(filterChainDefinitionMap) ;
return bean ;
这样也没有发现错误,然后后面再次缕了一遍,并在浏览器控制台看一下source的路径, 发现静态资源的路径前面是没有static的, 因而shiro也不会放行,
因为springboot默认会将static目录中的内容做为classes根目录的内容发布到web服务器, 所以如果想要放行静态资源, 同时又要实现拦截/**请求,必须将过滤静态文件的请求的路径更改到statics文件下,如下所示:
//配置访问权限的路径
LinkedHashMap<String , String> filterChainDefinitionMap = new LinkedHashMap<>() ;
//过滤静态文件请求
filterChainDefinitionMap.put("/statics/**" , "anon") ;
//过滤访问swagger请求
filterChainDefinitionMap.put("/swagger-resources/**" , "anon") ;
filterChainDefinitionMap.put("/v2/api-docs/**" , "anon") ;
filterChainDefinitionMap.put("/webjars/**" , "anon") ;
filterChainDefinitionMap.put("/swagger-ui.html" , "anon") ;
//过滤登录请求
filterChainDefinitionMap.put("/login.html" , "anon") ;
filterChainDefinitionMap.put("/login" , "anon") ;
filterChainDefinitionMap.put("/doLogin" , "anon") ;
//过滤默认访问界面请求
filterChainDefinitionMap.put("/" , "anon") ;
//过滤注销请求
filterChainDefinitionMap.put("/logout*" , "anon") ;
//对页面访问进行拦截验证
filterChainDefinitionMap.put("/*.html" , "authc") ;
filterChainDefinitionMap.put("/*" , "authc") ;
filterChainDefinitionMap.put("/**" , "authc") ;
filterChainDefinitionMap.put("/*.*" , "authc") ;
bean.setFilterChainDefinitionMap(filterChainDefinitionMap) ;
return bean ;
然后再试下,还是一样不行,再百度看下,检查项目的pom文件,发现没有读取静态文件,配置如下:
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
<include>**/*.yml</include>
<include>**/*.html</include>
<include>**/*.js</include>
<include>**/*.css</include>
<include>**/*.png</include>
<include>**/*.ico</include>
</includes>
<filtering>false</filtering>
</resource>
再次重启项目,并清除了浏览器的缓存后,对项目进行访问,发现已经将静态文件引入了:
写的有点乱,最后还是总结下吧,对于静态文件引入到thymeleaf模板中出现404没找到的错误,具体需要检查这几个方面:
1、检查引入的路径是否正确,检查路径是否正确,可以使用ctrl+鼠标左键,看看是否可以进入文件,如果可以,则表示路径正确
注意:使用thymeleaf模板语法引入的话,不需要加static;
如:
左边是普通引用,右边是使用thymeleaf模板语言进行引入,对比下就可以发现区别
2、检查pom文件中是否对配置文件夹下的文件进行读取,如下是我一个小案例的样板:
<!--读取配置文件-->
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
<include>**/*.yml</include>
<include>**/*.html</include>
<include>**/*.js</include>
<include>**/*.css</include>
<include>**/*.png</include>
<include>**/*.ico</include>
</includes>
<filtering>false</filtering>
</resource> <resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
<include>**/*.yml</include>
<include>**/*.html</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
因为静态文件都放置在resources/static下,所以对于js、css等引入只需在src/main/resources下写即可
3、检查项目中是否加了过滤器或拦截器,主要是检查它们是否对静态资源的路径进行过滤了,这个需要注意的。
4、检查项目是否整合了其他什么权限框架,比如shiro或spring security等,如果整合了,就需要检查下权限配置的代码中是否对静态文件进行过滤了,
需要注意的是,springboot默认会将static目录中的内容做为classes根目录的内容发布到web服务器, 所以如果想要放行静态资源, 同时又要实现拦截/**请求,
建议在static文件夹下再新建一个文件夹来存放静态资源文件,这样方便管理。
以上便是我上午使用springboot整合shiro时出现的一个粗心错误,有说的不恰当的地方可以及时提出!
基于springboot1.5.9整合shiro时出现静态文件找不到的问题的更多相关文章
- springboot2.0整合shiro出现ShiroDialect报错 找不到org/thymeleaf/processor/attr/AbstractTextChildModifierAttrPr
包版本过低,找最新包 https://mvnrepository.com/ <dependency> <groupId>com.github.theborakompanioni ...
- Django学习之天气调查实例(3):部署静态文件CSS、JS、images等(部署环境基于Ubuntu)
在设计登录界面时,采用了网上下载的登录模板,漂亮,简易.但是在测试和部署时,发现原来模板中采用的js文件和css文件,却着实让我折腾了好几天. 在以往的网页设计中,一般只要把测试站点开启后,网页中的静 ...
- SpringBoot整合Shiro实现基于角色的权限访问控制(RBAC)系统简单设计从零搭建
SpringBoot整合Shiro实现基于角色的权限访问控制(RBAC)系统简单设计从零搭建 技术栈 : SpringBoot + shiro + jpa + freemark ,因为篇幅原因,这里只 ...
- SpringMVC整合Shiro——(3)
SpringMVC整合Shiro,Shiro是一个强大易用的Java安全框架,提供了认证.授权.加密和会话管理等功能. 第一步:配置web.xml <!-- 配置Shiro过滤器,先让Shiro ...
- Spring整合Shiro做权限控制模块详细案例分析
1.引入Shiro的Maven依赖 <!-- Spring 整合Shiro需要的依赖 --> <dependency> <groupId>org.apache.sh ...
- Spring整合Shiro并扩展使用EL表达式
Shiro是一个轻量级的权限控制框架,应用非常广泛.本文的重点是介绍Spring整合Shiro,并通过扩展使用Spring的EL表达式,使@RequiresRoles等支持动态的参数.对Shiro的介 ...
- 补习系列(6)- springboot 整合 shiro 一指禅
目标 了解ApacheShiro是什么,能做什么: 通过QuickStart 代码领会 Shiro的关键概念: 能基于SpringBoot 整合Shiro 实现URL安全访问: 掌握基于注解的方法,以 ...
- spring boot整合shiro后,部分注解(Cache缓存、Transaction事务等)失效的问题
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/elonpage/article/details/78965176 前言 整合有缓存.事务的sprin ...
- SpringMVC整合Shiro,Shiro是一个强大易用的Java安全框架,提供了认证、授权、加密和会话管理等功能
SpringMVC整合Shiro,Shiro是一个强大易用的Java安全框架,提供了认证.授权.加密和会话管理等功能. 第一步:配置web.xml <!-- 配置Shiro过滤器,先让Shiro ...
随机推荐
- RDD(七)——依赖
概述 RDD只支持粗粒度转换,即在大量记录上执行的单个操作.将创建RDD的一系列Lineage(血统)记录下来,以便恢复丢失的分区.RDD的Lineage会记录RDD的元数据信息和转换行为,当该RDD ...
- layui从url中取值 ajax获取当前链接中的变量
在使用layui(javascript)的时候, 需要从当前页面的url地址中取值, 例如: http://localhost:8081/html/fund-purchase.html?fundID ...
- Apsara Clouder专项技能认证:实现调用API接口
一.API 简介 1.API 的概念 API(Application Programming Interface应用程序编程接口)是一些预定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访 ...
- BigDecimal进行精确运算
public class Test_1 { public static void main(String[] args) { System.out.println(0.06+0.01); System ...
- RadixSort(基数排序)原理及C++代码实现
基数排序是一种思想很值得学习的排序方法. 它突破了正常的排序思维:先排高位,如果高位相同再排次高位,直至最低.它的思想是利用稳定排序从低位开始排,最后再排最高位. 另外它用来划分的位不一定是一位一位的 ...
- iOS有关通讯录操作
一.首先获取用户通讯录授权信息. 在AppDelegate中导入#import <AddressBook/AddressBook.h>框架,在下列方法中获取授权信息. - (BOOL)ap ...
- 分布式全局唯一ID与自增序列
包含时间顺序的ID 此场景最简单的实现方案,就是采用 twitter 的 Snowflake 算法.ID总长64位,第1位不可用,41位表示时间戳,10位表示生成机器的id,后12位表示序列号. 为什 ...
- Android内存调优的一些方法
一.巧妙使用软引用和弱引用 软引用,系统内存紧张时会回收软引用对象,一般用用高速缓存,例如图片缓存,我们一般通过内存缓存图片来提高图片加载速度,但内存吃紧的时候可以通过软引用及时对图片资源回收. 弱引 ...
- [LC] 82. Remove Duplicates from Sorted List II
Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numb ...
- 响应式WEB页面开发实践
转自:https://github.com/markyun/My-blog/issues/27 最近得到一个新任务单,让我用一套页面适应所有主流终端(Android.iPhone.iPad.PC),而 ...