shiro安全框架—最简单的jdbcRealm的shiro验证通过
一、环境:
maven项目:
<!-- shiro驱动包 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.9</version>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-core</artifactId>
<version>1.2.2</version>
</dependency>
<!-- jdbc连接驱动包 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.25</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>0.2.23</version>
</dependency>
二、数据库表的设计:三、shiro.ini文件的编写:
<!--用于连接jdbc数据源的还有创建显得jdbcRealm-->
[main]
jdbcRealm=org.apache.shiro.realm.jdbc.JdbcRealm
dataSource=com.alibaba.druid.pool.DruidDataSource
dataSource.driverClassName=com.mysql.jdbc.Driver
dataSource.url=jdbc:mysql://192.168.191.144:3306/shiro?useUnicode=true&characterEncoding=UTF-8
dataSource.username=root
dataSource.password=123456
jdbcRealm.dataSource=$dataSource
securityManager.realms=$jdbcRealm
四、测试类编写:
public class JdbcRealmTest {
public static void main(String[] args) {
Factory<SecurityManager> factory=new IniSecurityManagerFactory("classpath:shiro.ini");
SecurityManager securityManager=factory.getInstance();
SecurityUtils.setSecurityManager(securityManager);
Subject subject = SecurityUtils.getSubject();
UsernamePasswordToken token=new UsernamePasswordToken("wang2","1233");
try {
subject.login(token);
if(subject.isAuthenticated()){
System.out.println("通过验证");
}
} catch (Exception e) {
System.out.println("没有通过身份验证");
}
subject.logout();
}
}
五、项目结构截图(只要按照我红框的来就行了,其他的是以前写的测试类)