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

建一个网站的费用企业网站建设与优化

建一个网站的费用,企业网站建设与优化,怎么做好网站开发_设计,广州网站建设首选快优一、会话相关API及会话使用 Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如Web容器Tomcat),可以在JavaSE和JavaEE环境中使用。会话相关API主要包括: Subject.getSession(): 获取当前用户的会话&#xff0…

一、会话相关API及会话使用

Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如Web容器Tomcat),可以在JavaSE和JavaEE环境中使用。会话相关API主要包括:

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

会话使用时,建议在Controller层使用原生的HttpSession对象,在Service层使用Shiro提供的Session对象。

二、缓存

问题分析

在每次访问设置了权限的页面时,Shiro都会执行doGetAuthorizationInfo()方法来获取权限信息。这可能导致性能问题,因为每次请求都需要重新计算权限。

解决办法

对权限授权数据进行缓存处理。可以使用第三方的Shiro-Redis集成Redis来实现缓存。

具体实现

  1. 在Shiro配置类中配置Redis缓存管理器。
  2. 在自定义Realm中使用缓存管理器来缓存权限信息。
  3. 在用户登录或权限变更时,手动清除缓存中的旧权限信息。

示例代码(Spring Boot环境):

// Shiro配置类  
@Configuration  
public class ShiroConfig {  // ...  @Bean  public RedisCacheManager cacheManager(RedisManager redisManager) {  RedisCacheManager cacheManager = new RedisCacheManager();  cacheManager.setRedisManager(redisManager);  return cacheManager;  }  // ...  
}  // 自定义Realm  
public class CustomRealm extends AuthorizingRealm {  // ...  @Autowired  private RedisCacheManager cacheManager;  @Override  protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {  // 从缓存中获取权限信息  String cacheKey = getAuthorizationCacheKey(principals);  AuthorizationInfo cachedAuthInfo = (AuthorizationInfo) cacheManager.getCache("authorizationCache").get(cacheKey);  if (cachedAuthInfo != null) {  return cachedAuthInfo;  }  // 如果缓存中没有,则查询数据库并缓存结果  AuthorizationInfo authInfo = // 查询数据库获取权限信息  cacheManager.getCache("authorizationCache").put(cacheKey, authInfo);  return authInfo;  }  // ...  private String getAuthorizationCacheKey(PrincipalCollection principals) {  // 生成缓存键,例如使用用户名  return principals.getPrimaryPrincipal().toString();  }  // 清除缓存的方法  public void clearCachedAuthorizationInfo(PrincipalCollection principals) {  String cacheKey = getAuthorizationCacheKey(principals);  cacheManager.getCache("authorizationCache").remove(cacheKey);  }  
}
演示测试

在测试环境中,可以通过模拟用户登录和访问受保护资源来验证缓存是否生效。观察日志或调试信息,确认Shiro是否从缓存中获取了权限信息而不是每次都查询数据库。

三、加密

哈希与盐

为了增强密码的安全性,Shiro支持使用哈希算法对密码进行加密,并可以添加盐值以防止彩虹表攻击。

加密与验证

在Shiro中,可以通过配置HashedCredentialsMatcher来实现密码的哈希加密和验证。HashedCredentialsMatcher可以设置哈希算法(如MD5、SHA-256等)和哈希迭代次数。

具体实现
  1. 在Shiro配置类中配置HashedCredentialsMatcher
  2. 在自定义Realm中使用HashedCredentialsMatcher进行密码验证。

示例代码:

// Shiro配置类  
@Configuration  
public class ShiroConfig {  // ...  @Bean  public HashedCredentialsMatcher hashedCredentialsMatcher() {  HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher();  hashedCredentialsMatcher.setHashAlgorithmName("MD5"); // 设置哈希算法  hashedCredentialsMatcher.setHashIterations(1024); // 设置哈希迭代次数  return hashedCredentialsMatcher;  }  @Bean  public SecurityManager securityManager(CustomRealm customRealm) {  DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();  securityManager.setRealm(customRealm);  securityManager.setCredentialsMatcher(hashedCredentialsMatcher()); // 设置密码加密验证器  return securityManager;  }  // ...  
}  // 自定义Realm  
public class CustomRealm extends AuthorizingRealm {  // ...  @Override  protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {  UsernamePasswordToken upToken = (UsernamePasswordToken) token;  String username = upToken.getUsername();  // 查询数据库获取用户信息  User user = userService.findUserByName(username);  if (user == null) {  throw new UnknownAccountException("用户不存在");  }  // 返回认证信息,包含用户名、密码(已加密)、盐值和Realm名称  return new SimpleAuthenticationInfo(user.getUsername(), user.getPassword(), ByteSource.Util.bytes(user.getSalt()), getName());  }  // ...  
}

在上面的代码中,User类应该包含用户名、密码(已加密)、盐值等属性。在注册用户时,应该使用与HashedCredentialsMatcher相同的哈希算法和迭代次数对密码进行加密,并将加密后的密码和盐值存储在数据库中。

四、登录次数限制

Shiro本身没有直接提供登录次数限制的功能,但可以通过自定义Realm或拦截器来实现。例如,可以在自定义Realm中维护一个登录失败次数的计数器,当登录失败次数超过一定限制时,可以锁定用户账户或增加额外的验证步骤。

实现登录次数限制的示例代码(简化版):

// 自定义Realm  
public class CustomRealm extends AuthorizingRealm {  // ...  private Map<String, Integer> loginFailureCounts = new ConcurrentHashMap<>(); // 登录失败次数计数器  private static final int MAX_FAILURE_COUNT = 5; // 最大失败次数限制  @Override  protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {  UsernamePasswordToken upToken = (UsernamePasswordToken) token;  String username = upToken.getUsername();  // 检查登录失败次数是否超过限制  if (loginFailureCounts.getOrDefault(username, 0) >= MAX_FAILURE_COUNT) {  throw new LockedAccountException("账户已被锁定,请稍后再试");  }  // 查询数据库获取用户信息  User user = userService.findUserByName(username);  if (user == null) {  // 登录失败,增加失败次数计数器  loginFailureCounts.put(username, loginFailureCounts.getOrDefault(username, 0) + 1);  throw new UnknownAccountException("用户不存在");  }  // 验证密码(省略具体实现)  // ...  // 登录成功,清除失败次数计数器  loginFailureCounts.remove(username);  // 返回认证信息  return new SimpleAuthenticationInfo(user.getUsername(), user.getPassword(), ByteSource.Util.bytes(user.getSalt()), getName());  }  // ...  
}
http://www.laogonggong.com/news/84399.html

相关文章:

  • 门户网站个人可以做想学ui设计从哪里入手
  • 苏州市建设交易中心网站首页东莞网站建设制作软件
  • 网站升级维护区块链app定制开发
  • 网站开发需要学些什么赣州九一人才网手机版
  • 自己做的视频发什么网站吗网站运营实例
  • 好听的广告公司名字关键词优化价格
  • 怎么让网站排名下降网站建设公司找客户
  • 全flash网站制作做网站代码编辑工具
  • 群辉做网站服务器pythonwordpress主题ftp失败
  • 企业建设网站预算泰州网站关键词优化
  • 网站建设山东聚搜网络一x设计方案怎么做
  • 网站后台如何做产品展示网站建设代运营方案
  • 网站备案单位查询系统国外服务器电商网站
  • drupal 网站开发手机网站 微信支付
  • 做公益活动的网站在线代理入口
  • 如何设置网站布局vi设计包含哪些内容
  • 建盏公司官方网站驻马店百牛网站建设
  • 如何让网站免费濮阳创建网站公司
  • 网站制作信息金螳螂装饰公司
  • vs做网站不显示图片做网站需不需要购买服务器
  • 做网站效果品牌网站建设公司哪家好
  • 备案平台资阳网站seo
  • 网页是网站吗苏州网站建设白石
  • 外贸网站wordpress主题免费下载
  • 网站的jsp页面怎么做python基础教程雪峰
  • 注册网站授权书怎么写vs2015是网站开发
  • 微站电池中国网站排名 优帮云
  • 专业网站建设新闻网站怎么做安全
  • 导购网站制作广州网络推广万企在线
  • 河北省住房建设厅政务网站医院网站建设要素