shiro学习笔记(7)——加密MD5+盐salt+凭证匹配器+注解授权+jsp标签授权

5.12 shiro的过虑器

过滤器简称

对应的java类

anon

org.apache.shiro.web.filter.authc.AnonymousFilter

authc

org.apache.shiro.web.filter.authc.FormAuthenticationFilter

authcBasic

org.apache.shiro.web.filter.authc.BasicHttpAuthenticationFilter

perms

org.apache.shiro.web.filter.authz.PermissionsAuthorizationFilter

port

org.apache.shiro.web.filter.authz.PortFilter

rest

org.apache.shiro.web.filter.authz.HttpMethodPermissionFilter

roles

org.apache.shiro.web.filter.authz.RolesAuthorizationFilter

ssl

org.apache.shiro.web.filter.authz.SslFilter

user

org.apache.shiro.web.filter.authc.UserFilter

logout

org.apache.shiro.web.filter.authc.LogoutFilter

 

anon:例子/admins/**=anon 没有参数,表示可以匿名使用。

authc:例如/admins/user/**=authc表示需要认证(登录)才能使用,FormAuthenticationFilter是表单认证,没有参数

perms:例子/admins/user/**=perms[user:add:*],参数可以写多个,多个时必须加上引号,并且参数之间用逗号分割,例如/admins/user/**=perms["user:add:*,user:modify:*"],当有多个参数时必须每个参数都通过才通过,想当于isPermitedAll()方法。

user:例如/admins/user/**=user没有参数表示必须存在用户, 身份认证通过或通过记住我认证通过的可以访问,当登入操作时不做检查

 

 5.13 认证

  5.13.1 需求

修改realm的doGetAuthenticationInfo,从数据库查询用户信息,realm返回的用户信息中包括 (md5加密后的串和salt),实现让shiro进行散列串的校验。

 

​​​​​​​​​​​​​​  5.13.2 修改doGetAuthenticationInfo从数据库查询用户信息

 

1、将SysService注入到realm中。

 

 

//realm的认证方法,从数据库查询用户信息

@Override

protected AuthenticationInfo doGetAuthenticationInfo(

AuthenticationToken token) throws AuthenticationException {

 

// token是用户输入的用户名和密码

// 第一步从token中取出用户名

String userCode = (String) token.getPrincipal();

 

// 第二步:根据用户输入的userCode从数据库查询

SysUser sysUser = null;

try {

sysUser = sysService.findSysUserByUserCode(userCode);

} catch (Exception e1) {

// TODO Auto-generated catch block

e1.printStackTrace();

}

 

// 如果查询不到返回null

if(sysUser==null){//

return null;

}

// 从数据库查询到密码

String password = sysUser.getPassword();

 

//盐

String salt = sysUser.getSalt();

 

// 如果查询到返回认证信息AuthenticationInfo

 

//activeUser就是用户身份信息

ActiveUser activeUser = new ActiveUser();

 

activeUser.setUserid(sysUser.getId());

activeUser.setUsercode(sysUser.getUsercode());

activeUser.setUsername(sysUser.getUsername());

//..

 

//根据用户id取出菜单

List<SysPermission> menus  = null;

try {

//通过service取出菜单

menus = sysService.findMenuListByUserId(sysUser.getId());

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

//将用户菜单 设置到activeUser

activeUser.setMenus(menus);

 

 

//将activeUser设置simpleAuthenticationInfo

SimpleAuthenticationInfo simpleAuthenticationInfo = new SimpleAuthenticationInfo(

activeUser, password,ByteSource.Util.bytes(salt), this.getName());

 

return simpleAuthenticationInfo;

}

 

​​​​​​​  5.13.3 设置凭证匹配器

数据库中存储到的md5的散列值,在realm中需要设置数据库中的散列值它使用散列算法 及散列次数,让shiro进行散列对比时和原始数据库中的散列值使用的算法 一致。

 

 

 

 

 

 

5.14 授权

  5.14.1 需求

修改realm的doGetAuthorizationInfo,从数据库查询权限信息。

使用注解式授权方法。

使用jsp标签授权方法。

 

  ​​​​​​​5.14.2 修改doGetAuthorizationInfo从数据库查询权限

 

// 用于授权

@Override

protected AuthorizationInfo doGetAuthorizationInfo(

PrincipalCollection principals) {

 

//从 principals获取主身份信息

//将getPrimaryPrincipal方法返回值转为真实身份类型(在上边的doGetAuthenticationInfo认证通过填充到SimpleAuthenticationInfo中身份类型),

ActiveUser activeUser =  (ActiveUser) principals.getPrimaryPrincipal();

 

//根据身份信息获取权限信息

//从数据库获取到权限数据

List<SysPermission> permissionList = null;

try {

permissionList = sysService.findPermissionListByUserId(activeUser.getUserid());

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

//单独定一个集合对象

List<String> permissions = new ArrayList<String>();

if(permissionList!=null){

for(SysPermission sysPermission:permissionList){

//将数据库中的权限标签 符放入集合

permissions.add(sysPermission.getPercode());

}

}

 

 

//查到权限数据,返回授权信息(要包括 上边的permissions)

SimpleAuthorizationInfo simpleAuthorizationInfo = new SimpleAuthorizationInfo();

//将上边查询到授权信息填充到simpleAuthorizationInfo对象中

simpleAuthorizationInfo.addStringPermissions(permissions);

 

return simpleAuthorizationInfo;

}

 

 

 

  ​​​​​​​5.14.3 开启controller类aop支持

对系统中类的方法给用户授权,建议在controller层进行方法授权。

 

在springmvc.xml中配置:

 

   ​​​​​​​5.14.4 在controller方法中添加注解

 

 

 

 

 

​​​​​​​​​​​​​​  5.14.5 jsp标签 授权

 

Jsp页面添加:

<%@ tagliburi="http://shiro.apache.org/tags" prefix="shiro" %>

 

标签名称

标签条件(均是显示标签内容)

<shiro:authenticated>

登录之后

<shiro:notAuthenticated>

不在登录状态时

<shiro:guest>

用户在没有RememberMe时

<shiro:user>

用户在RememberMe时

<shiro:hasAnyRoles name="abc,123" >

在有abc或者123角色时

<shiro:hasRole name="abc">

拥有角色abc

<shiro:lacksRole name="abc">

没有角色abc

<shiro:hasPermission name="abc">

拥有权限资源abc

<shiro:lacksPermission name="abc">

没有abc权限资源

<shiro:principal>

显示用户身份名称

 <shiro:principal property="username"/>     显示用户身份中的属性值

 

修改itemsList.jsp页面:

 

  ​​​​​​​​​​​​​​5.14.6 授权测试

 

当调用controller的一个方法,由于该 方法加了@RequiresPermissions("item:query") ,shiro调用realm获取数据库中的权限信息,看"item:query"是否在权限数据中存在,如果不存在就拒绝访问,如果存在就授权通过。

 

当展示一个jsp页面时,页面中如果遇到<shiro:hasPermission name="item:update">,shiro调用realm获取数据库中的权限信息,看item:update是否在权限数据中存在,如果不存在就拒绝访问,如果存在就授权通过。

 

问题:只要遇到注解或jsp标签的授权,都会调用realm方法查询数据库,需要使用缓存解决此问题。

猜你喜欢

转载自blog.csdn.net/xinpz/article/details/81556925
今日推荐