当前位置: 首页 > news >正文

新建茶叶网站文章内容建设腾讯推广联盟

新建茶叶网站文章内容建设,腾讯推广联盟,用visual做的网站,国内大型网站制作学习目标 11.1 会话管理11.1.1 会话相关API一、获取会话二、会话属性管理三、会话信息获取四、会话控制五、会话监听六、会话DAO七、会话验证 11.2 缓存一、缓存接口二、内置缓存实现三、配置缓存四、使用缓存五、缓存清理六、注意事项 前面两章我们已经掌握了Shiro四大基石的认…

学习目标

  • 11.1 会话管理
    • 11.1.1 会话相关API
      • 一、获取会话
      • 二、会话属性管理
      • 三、会话信息获取
      • 四、会话控制
      • 五、会话监听
      • 六、会话DAO
      • 七、会话验证
    • 11.2 缓存
      • 一、缓存接口
      • 二、内置缓存实现
      • 三、配置缓存
      • 四、使用缓存
      • 五、缓存清理
      • 六、注意事项

  前面两章我们已经掌握了Shiro四大基石的认证和授权,(如果没有了解可以去我主页看看 第九至十章的内容来学习)且基于SpringBoot+Shiro实现了动态认证和授权,基本完成CRM客户关系管理系统重的权限控制。
  本章我们学习另两个基石:会话管理和加密,并对上章的动态授权进行优化,使用Redis缓存用户权限信息。

11.1 会话管理

11.1.1 会话相关API

Shiro是一个强大的Java安全框架,提供了完整的企业级会话管理功能。在Shiro中,与会话相关的API主要包括以下几个方面:

一、获取会话

  • Subject.getSession():获取当前用户的会话。如果当前没有创建会话对象,则会创建一个新的会话。这等价于Subject.getSession(true)。
  • Subject.getSession(boolean create):根据参数决定是否创建一个新的会话。如果create为true且当前没有会话,则创建一个新的会话;如果为false且当前没有会话,则返回null。

二、会话属性管理

  • session.setAttribute(key, value):设置会话属性。
  • session.getAttribute(key):获取会话属性。
  • session.removeAttribute(key):删除会话属性。

三、会话信息获取

  • session.getId():获取当前会话的唯一标识。
  • session.getHost():获取当前Subject的主机地址。在会话开始时,Shiro会存储用户的IP地址和主机名,以此可以判断用户的位置。
  • session.getTimeout() & session.setTimeout(毫秒):获取/设置当前Session的过期时间。
  • session.getStartTimestamp() & session.getLastAccessTime():获取会话的启动时间及最后访问时间。如果是JavaSE应用,需要自己定期调用session.touch()去更新最后访问时间;如果是JavaEE应用,每次进入ShiroFilter都会自动调用session.touch()来更新最后访问时间。

四、会话控制

  • session.touch():更新会话的最后访问时间,让会话保持活跃状态。
  • session.stop():销毁会话。当调用Subject.logout()时,会自动调用session.stop()方法来销毁会话。在Web应用中,调用HttpSession.invalidate()也会自动调用session.stop()来销毁Shiro的会话。

五、会话监听

Shiro提供了会话监听器,用于监听会话的创建、过期及停止事件。要实现自己的会话监听器,需要实现SessionListener接口,并重写以下方法:

  • onStart(Session session):监听会话创建事件。
  • onStop(Session session):监听会话销毁事件。
  • onExpiration(Session session):监听会话过期事件。

六、会话DAO

Shiro提供了SessionDAO接口及其多种实现,用于会话的CRUD(创建、读取、更新、删除)操作。常用的实现类包括:

  • AbstractSessionDAO:提供了SessionDAO的基础实现,如生成会话ID等。
  • CachingSessionDAO:提供了对开发者透明的会话缓存功能,需要设置相应的CacheManager。
  • MemorySessionDAO:直接在内存中进行会话维护。
  • EnterpriseCacheSessionDAO:提供了缓存功能的会话维护,默认情况下使用MapCache实现,内部使用ConcurrentHashMap保存缓存的会话。

七、会话验证

Shiro提供了会话验证调度器,用于定期验证会话是否已过期。如果过期,将停止会话。Shiro提供了两种会话验证调度器:

  • SessionValidationScheduler:默认的会话验证调度器。
  • QuartzSessionValidationScheduler:使用Quartz作为定时任务的会话验证调度器。使用Quartz时需要导入shiro-quartz依赖。

以上内容涵盖了Shiro中与会话相关的API及其主要功能。开发者可以根据这些API和功能来实现自定义的会话管理逻辑。

11.2 缓存

在Apache Shiro中,缓存是提高性能和效率的关键组件。Shiro提供了多种缓存实现,允许开发者根据需求选择合适的缓存机制。以下是Shiro中与缓存相关的关键概念和代码示例:

一、缓存接口

Shiro的缓存接口主要包括Cache<K, V>和CacheManager。

  • Cache<K, V>:定义了缓存的基本操作,如获取、放入、删除缓存项等。
  • CacheManager:管理多个缓存实例的工厂,可以根据缓存的名称获取对应的缓存实例。

二、内置缓存实现

Shiro提供了几种内置的缓存实现:

  • MemoryConstrainedCacheManager:基于内存的缓存管理器,可以设置缓存的最大数量和每个缓存项的最大大小。
  • EhcacheManager:集成Ehcache作为缓存实现。
  • HazelcastCacheManager:集成Hazelcast作为分布式缓存实现。
  • JCacheManager:集成JSR-107(Java缓存API)作为缓存实现。

三、配置缓存

在Shiro的配置文件中(如shiro.ini或Spring配置文件),可以配置缓存管理器。

例如,在shiro.ini中配置Ehcache:

[main]  
cacheManager = org.apache.shiro.cache.ehcache.EhCacheManager  
cacheManager.configLocation = classpath:ehcache.xml  
securityManager.cacheManager = $cacheManager

在Spring配置中,可以这样配置:

<bean id="cacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager">  <property name="configLocation" value="classpath:ehcache.xml"/>  
</bean>  
<bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">  <property name="cacheManager" ref="cacheManager"/>  <!-- 其他配置 -->  
</bean>

四、使用缓存

在Shiro中,缓存通常用于存储授权信息(如角色和权限)和身份验证信息(如用户信息和会话)。开发者可以在自定义的Realm或过滤器中使用缓存来提高性能。

例如,在自定义Realm中,可以使用缓存来存储从数据库或其他数据源加载的用户信息和权限信息:

public class MyRealm extends AuthorizingRealm {  // 假设有一个缓存实例  private Cache<String, AuthorizationInfo> authorizationCache;  @Override  protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {  String username = (String) principals.getPrimaryPrincipal();  AuthorizationInfo info = authorizationCache.get(username);  if (info == null) {  // 从数据源加载授权信息  info = loadAuthorizationInfo(username);  // 将授权信息放入缓存  authorizationCache.put(username, info);  }  return info;  }  // 加载授权信息的方法  private AuthorizationInfo loadAuthorizationInfo(String username) {  // 实现从数据源加载授权信息的逻辑  }  // 设置缓存实例的方法(通常在Spring配置中注入)  public void setAuthorizationCache(Cache<String, AuthorizationInfo> authorizationCache) {  this.authorizationCache = authorizationCache;  }  
}

五、缓存清理

由于缓存中的数据可能会过期或无效,因此需要定期清理缓存。Shiro的缓存实现通常会自动处理缓存过期和清理的问题,但开发者也可以根据需要手动清理缓存。

例如,在Ehcache中,可以通过配置元素来设置缓存的清理策略,如LRU(最近最少使用)、LFU(最不经常使用)等。

在Shiro的自定义实现中,也可以调用Cache.clear()方法来手动清理缓存。

六、注意事项

  • 缓存中的数据可能是敏感的,因此要确保缓存的配置和访问控制是安全的。
  • 缓存的性能提升是以牺牲内存为代价的,因此要合理设置缓存的大小和清理策略。
  • 在分布式环境中,要使用分布式缓存解决方案来确保数据的一致性。

通过以上配置和使用方法,开发者可以在Shiro中充分利用缓存来提高应用程序的性能和效率。

http://www.yayakq.cn/news/346737/

相关文章:

  • 网站有哪些备案app企业网站模板免费下载
  • 申请免费网站主页空间医疗整形网站怎么做
  • 如何做推广麦当劳的网站手机如何制作app
  • 做营销型网站的企业山西省住房建设厅网站房屋建筑定额
  • 南京做网站建设的公司保定头条新闻最新今天
  • wps如何做网站网站小程序
  • 描述网站建设的基本流程网站对应的ip地址吗
  • 中小企业建设网站应注意wordpress load-scripts.php
  • 网页设计大赛网站开发dedecms教育h5网站模板
  • dz论坛网站模板下载wordpress首页调用产品
  • 网站是如何建立的八闽视频app下载
  • 京东网站拼图验证怎么做为什么不建议去外包公司
  • 深圳建网站公司怎么选择洛阳又发现一例
  • 慈溪市网站开发关键词app下载
  • 临沂网站关键词微信 网站 优劣势
  • 网站打包app免费软件库下载
  • 北京微信网站开发网站空间到期影响
  • 新河镇网站制作系统开发流程和步骤
  • 商城网站制作做一个网址需要多少钱
  • 服装网站模板下载天津武清做网站的公司
  • 网站设计的公司叫什么温岭做网站公司
  • 西安优秀网站设计网站建设一般要多少钱
  • 毕设做网站什么能过试用体验网站
  • 网站制作 代码编辑德阳互联免费云主机
  • 网站建设公众号小程序开发阿里巴巴上怎样做自己的网站
  • 坪山手机网站建设wordpress缓存无法清除缓存
  • 秦皇岛和平大街网站建设网页设计的常用工具有哪些
  • 搜索引擎营销网站网页页面设计代码
  • 品牌专业建设网站哈尔滨专利局申请专利地址
  • 怎么做自动发卡的网站个人域名备案后不能干什么