在前一篇Shiro必会之利用标签实现权限检测文章之中,我们已经利用SSM框架实现用户权限检测,这次我们还是实现完全相同的功能。不过用的是SpringBoot整合Shiro、Thymeleaf和JPA。
原先的5张表数据不动,不做任何修改。创建一个Springboot工程,拷贝相关的类和页面。项目结构如下:
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
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