springboot打印sql_Springboot整合Shiro实现权限检测

本文介绍如何在SpringBoot项目中使用Shiro、Thymeleaf和JPA来实现用户权限检测。通过创建SpringBoot工程,配置相关依赖,如Shiro的核心组件及JPA,不改动原有5张表数据,实现了与前文SSM框架相同的功能。项目涉及数据库连接、JPA配置、Thymeleaf模板引擎的禁用缓存以及实体类和DAO接口的调整。
摘要由CSDN通过智能技术生成
fe790e4406f7627a10a2f3afd5561627.png

在前一篇Shiro必会之利用标签实现权限检测文章之中,我们已经利用SSM框架实现用户权限检测,这次我们还是实现完全相同的功能。不过用的是SpringBoot整合Shiro、Thymeleaf和JPA。

原先的5张表数据不动,不做任何修改。创建一个Springboot工程,拷贝相关的类和页面。项目结构如下:

570310ae96df097fc7020106978a2162.png

1、修改pom.xml,加入本次项目主要依赖包

com.github.theborakompanioni thymeleaf-extras-shiro 2.0.0org.springframework.boot spring-boot-starter-thymeleaforg.springframework.boot spring-boot-starter-weborg.springframework.boot spring-boot-starter-test testorg.springframework.boot spring-boot-starter-data-jpaorg.apache.shiro shiro-core 1.3.2org.apache.shiro shiro-web 1.3.2org.apache.shiro shiro-spring 1.3.2mysql mysql-connector-java 5.1.45runtimecom.alibaba fastjson 1.2.0net.sourceforge.nekohtml nekohtml

2、修改application.yml配置文件

server: port: 80spring: datasource: #数据库连接配置 url: jdbc:mysql://localhost:3306/shirodb username: root password: mysqladmin driver-class-name: com.mysql.jdbc.Driver jpa: #jpa相关配置 database: mysql show-sql: true # 开发环境打开sql打印方便查看 hibernate: ddl-auto: update # 直接建好表,每次只做更新,不似create,每次启动程序,没有表会新建,表内有数据会清空 naming: implicit-strategy: org.hibernate.boot.model.naming.ImplicitNamingStrategyJpaCompliantImpl physical-strategy: org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl properties: hibernate: dialect: org.hibernate.dialect.MySQL5Dialect thymeleaf: # 避免检测Html语法 cache: false mode: LEGACYHTML5

3、修改实体类Member、Role、Action,加上@Entity、@Id

7ee29b507bced660138177e65cb9616c.png

4、修改IMemberDAO接口、创建IRoleDAO、IActionDAO,接口继承JpaRepository

public interface IMemberDAO extends JpaRepository {}public interface IRoleDAO extends JpaRepository { /** * 查找用户所有角色 * @param mid * @return */ @Query(value = "SELECT r.* FROM role AS r LEFT JOIN member_role mr ON r.rid = mr.rid WHERE mr.mid = :mid
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值