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

网站欢迎页设计租用服务器网站

网站欢迎页设计,租用服务器网站,动漫制作专业报告,东莞市网站建设学习目标 11.1 会话管理11.1.1 会话相关API一、获取会话二、会话属性管理三、会话信息获取四、会话控制五、会话监听六、会话DAO七、会话验证 11.2 缓存一、缓存接口二、内置缓存实现三、配置缓存四、使用缓存五、缓存清理六、注意事项 前面两章我们已经掌握了Shiro四大基石的认… 学习目标 11.1 会话管理11.1.1 会话相关API一、获取会话二、会话属性管理三、会话信息获取四、会话控制五、会话监听六、会话DAO七、会话验证 11.2 缓存一、缓存接口二、内置缓存实现三、配置缓存四、使用缓存五、缓存清理六、注意事项 前面两章我们已经掌握了Shiro四大基石的认证和授权如果没有了解可以去我主页看看 第九至十章的内容来学习且基于SpringBootShiro实现了动态认证和授权基本完成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的缓存接口主要包括CacheK, V和CacheManager。 CacheK, V定义了缓存的基本操作如获取、放入、删除缓存项等。CacheManager管理多个缓存实例的工厂可以根据缓存的名称获取对应的缓存实例。 二、内置缓存实现 Shiro提供了几种内置的缓存实现 MemoryConstrainedCacheManager基于内存的缓存管理器可以设置缓存的最大数量和每个缓存项的最大大小。EhcacheManager集成Ehcache作为缓存实现。HazelcastCacheManager集成Hazelcast作为分布式缓存实现。JCacheManager集成JSR-107Java缓存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 idcacheManager classorg.apache.shiro.cache.ehcache.EhCacheManager property nameconfigLocation valueclasspath:ehcache.xml/ /bean bean idsecurityManager classorg.apache.shiro.web.mgt.DefaultWebSecurityManager property namecacheManager refcacheManager/ !-- 其他配置 -- /bean四、使用缓存 在Shiro中缓存通常用于存储授权信息如角色和权限和身份验证信息如用户信息和会话。开发者可以在自定义的Realm或过滤器中使用缓存来提高性能。 例如在自定义Realm中可以使用缓存来存储从数据库或其他数据源加载的用户信息和权限信息 public class MyRealm extends AuthorizingRealm { // 假设有一个缓存实例 private CacheString, 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(CacheString, AuthorizationInfo authorizationCache) { this.authorizationCache authorizationCache; } }五、缓存清理 由于缓存中的数据可能会过期或无效因此需要定期清理缓存。Shiro的缓存实现通常会自动处理缓存过期和清理的问题但开发者也可以根据需要手动清理缓存。 例如在Ehcache中可以通过配置元素来设置缓存的清理策略如LRU最近最少使用、LFU最不经常使用等。 在Shiro的自定义实现中也可以调用Cache.clear()方法来手动清理缓存。 六、注意事项 缓存中的数据可能是敏感的因此要确保缓存的配置和访问控制是安全的。缓存的性能提升是以牺牲内存为代价的因此要合理设置缓存的大小和清理策略。在分布式环境中要使用分布式缓存解决方案来确保数据的一致性。 通过以上配置和使用方法开发者可以在Shiro中充分利用缓存来提高应用程序的性能和效率。
http://www.w-s-a.com/news/897482/

相关文章:

  • 百度助手app下载苏州seo关键词优化排名
  • 17网站一起做 佛山诸城网站建设多少钱
  • 郑州网站建设培训学校泉州做网站设计公司
  • 西峡做网站深圳建筑工务署官网
  • 单县网站惠州seo计费
  • 万网网站建设 优帮云怎样用记事本做网站
  • 注册域名后网站建设百度指数的功能
  • 怎么做伪静态网站山西网站建设设计
  • 做小型企业网站多少钱衡阳市建设局网站
  • 金华专业网站建设公司网站建设空间和服务器方式
  • 自己做的网站在浏览器上显示不安全吗wordpress revolution slider
  • 西安网站建设推广优化搜索引擎营销
  • 互联网站备案管理工作方案 工信部注册深圳公司需要什么条件
  • 网站网站服务器网站建设 物流
  • 国外开发网站手机网站建设制作
  • 怎么把自己做的网站传网上青岛工程建设监理公司网站
  • 网站301跳转效果商丘网站公司
  • 公司网站建设西安网站的架构与建设
  • 食品科技学校网站模板花溪村镇建设银行网站
  • 图片渐隐 网站头部flash地方志网站建设自查报告
  • 深圳做商城网站视觉品牌网站建设
  • 永康电子商务网站建设弹幕网站怎么做
  • 百川网站企业做网站要注意哪些
  • 球迷类的网站如何做网站建设需要哪些素材
  • 请问有重庆有做网站吗电子政务系统网站建设的基本过程
  • 建设银行管方网站官网最新版cmsv6
  • 网站开发工程师需要会写什么深圳网站(建设信科网络)
  • 台州网站搭建网站建设需求计划
  • 网站app免费下载软件大全大连百度推广哪家好
  • 网站建设的面试要求iis做的网站手机怎么访问