SpringBoot 集成 Shiro 无法加载静态资源报 302,已知原因并已解决

解决前分析:

1. 我们来看一下 Shiro 的配置类

  • 按道理说,按照下面的配置的话是不会出现任何问题的。

 

2. 页面效果和报错

  • 出现了这样的错误:Uncaught SyntaxError: Unexpected token '<'
  • 大家看到这里,一般都会认为是前端页面的问题,实际上当我们页面确定没有错,引入的资源也确定是没有的,这时就是访问被拦截了。

3. Network分析

  • 通过下面的图,我们可以看到,所有的静态资源状态码都是302
    • 所以,可以更加的确定我们的所有的静态资源都被拦截了。

解决中分析:

1. 问题

  • 问题:到这里的话,肯定很多疑惑,我们命名不是在 Shiro 中放行了 static 中的资源了吗?为什么还是会被拦截?

2. 分析

  • 对的,就是因为我们放行的是静态资源。
  • 值得我们注意的是,在 SpringBoot 中,我们 static 下面的所有资源,在前端页面中进行引入的时候都是不需要加上 /static 的,因为 SpringBoot 会自动帮我们引入。
  • 也正是因为如此,所以页面中访问的静态资源都是没有加上 /static 的。

 3. 解决

  • 到这里,或许很多人已经豁然开朗了。
  • 我们接下来再看一下 Shiro 配置类的静态放行:
  • 可以看到的是,我们放行的是 /static/** ,也就是说,只有 访问路径中带有 /static/xx 的才不会被拦截,也就是放行的。但是在我们的访问路径中是没有 /static 的,所以就会被拦截掉。也就报 302 了。

解决后分析:

解决方案一:

  • 把 /static/** 配置静态放行去掉,然后把需要的所有的资源都一个一个的进行放行。
  • 如图所示:

 解决方案二:

  • 把所有的 static 下的静态资源,全部放到一个新的目录下,再把这个新的目录放到 static 下面。
  • 如图所示:

 

总结:此时,我们重新启动之后,就可以看到页面加载的效果,以及所有的静态资源都是加载成功的。

对你有帮助的话,点一下赞~ 呗,收藏~ 呗~~~~



 

  • 10
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
对于Spring Boot集成Shiro,你可以按照以下步骤进行操作: 1. 首先,在你的Spring Boot项目中添加Shiro的依赖。你可以在pom.xml文件中添加以下依赖关系: ```xml <dependency> <groupId>org.apache.shiro</groupId> <artifactId>shiro-spring-boot-starter</artifactId> <version>1.7.1</version> </dependency> ``` 2. 创建一个Shiro的配置类,用于配置Shiro的相关组件和属性。可以使用`@Configuration`注解来标记该类作为配置类,并使用`@EnableShiroAnnotation`注解来启用Shiro的注解支持。 ```java @Configuration @EnableShiroAnnotation public class ShiroConfig { // 配置Shiro的相关组件和属性 // ... } ``` 3. 在上述配置类中,可以配置Shiro的Realm、Session管理器、缓存管理器等组件。你可以根据自己的需求选择相应的实现类并进行配置。 ```java @Configuration @EnableShiroAnnotation public class ShiroConfig { @Bean public Realm realm() { // 配置自定义的Realm实现类 // ... return realm; } @Bean public SessionManager sessionManager() { // 配置自定义的Session管理器实现类 // ... return sessionManager; } @Bean public CacheManager cacheManager() { // 配置自定义的缓存管理器实现类 // ... return cacheManager; } // 其他配置项... } ``` 4. 在主配置类中,添加`@Import`注解来引入Shiro的配置类。 ```java @SpringBootApplication @Import(ShiroConfig.class) public class YourApplication { public static void main(String[] args) { SpringApplication.run(YourApplication.class, args); } } ``` 5. 在需要进行权限控制的地方,使用Shiro的注解来标记需要进行权限验证的方法或类。例如,可以使用`@RequiresRoles`注解来限制具有特定角色的用户才能访问方法。 ```java @RestController public class YourController { @RequiresRoles("admin") @GetMapping("/admin") public String admin() { return "Hello, admin!"; } } ``` 这样,你就成功地集成Spring BootShiro,并可以进行基于角色的权限控制了。当然,以上只是一个简单的示例,你可以根据自己的需求进行更详细的配置和使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

写BUG的ySir

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值