使用缓存,能够解决每次访问请求都查数据库的问题。第一次受权后存入缓存。数据库
shiro中提供了对认证信息和受权信息的缓存。shiro默认是关闭认证信息缓存的,对于受权信息的缓存shiro默认开启的。主要研究受权信息缓存,由于受权的数据量大。编程
用户认证经过。缓存
该 用户第一次受权:调用realm查询数据库框架
该 用户第二次受权:不调用realm查询数据库,直接从缓存中取出受权信息(权限标识符)。测试
若是用户正常退出,缓存自动清空。spa
若是用户非正常退出,缓存自动清空。code
若是修改了用户的权限,而用户不退出系统,修改的权限没法当即生效。xml
须要手动进行编程实现:blog
在权限修改后调用realm的clearCache方法清除缓存。ip
正常开发时要放在service中调用。
在service中,权限修改后调用realm的清空缓存方法。
// 清除缓存 public void clearCached() { PrincipalCollection principals = SecurityUtils.getSubject().getPrincipals(); super.clearCache(principals); }