Apache Tomee与GemFire集成的会话管理
创始人
2024-09-05 01:30:33
0

要在Apache Tomee和GemFire之间集成会话管理,可以使用Apache Shiro作为安全框架,并使用GemFire作为会话存储。

以下是一个简单的示例代码,演示了如何在Apache Tomee中集成Apache Shiro和GemFire:

  1. 首先,您需要在pom.xml文件中添加以下依赖项:

    org.apache.shiro
    shiro-core
    1.7.1


    org.apache.shiro
    shiro-web
    1.7.1


    org.apache.shiro
    shiro-gemfire
    1.7.1


    io.pivotal.gemfire
    gemfire
    9.8.6

  1. 创建一个GemFire会话管理器类,实现org.apache.shiro.session.mgt.SessionManager接口:
import org.apache.shiro.session.Session;
import org.apache.shiro.session.mgt.SessionContext;
import org.apache.shiro.session.mgt.SessionManager;
import org.apache.shiro.session.mgt.eis.AbstractSessionDAO;
import org.apache.shiro.session.mgt.eis.EnterpriseCacheSessionDAO;

public class GemFireSessionManager extends AbstractSessionDAO implements SessionManager {

    private EnterpriseCacheSessionDAO sessionDAO;

    public GemFireSessionManager() {
        this.sessionDAO = new EnterpriseCacheSessionDAO();
    }

    @Override
    public Session start(SessionContext sessionContext) {
        return sessionDAO.create(sessionContext);
    }

    @Override
    public Session getSession(SessionKey sessionKey) {
        return sessionDAO.readSession(sessionKey);
    }

    @Override
    public void update(Session session) {
        sessionDAO.update(session);
    }

    @Override
    public void delete(Session session) {
        sessionDAO.delete(session);
    }
}
  1. 创建一个Shiro配置类,配置GemFire作为会话管理器:
import org.apache.shiro.cache.MemoryConstrainedCacheManager;
import org.apache.shiro.session.mgt.SessionManager;
import org.apache.shiro.session.mgt.eis.EnterpriseCacheSessionDAO;
import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
import org.apache.shiro.web.mgt.WebSecurityManager;
import org.apache.shiro.web.servlet.AbstractShiroFilter;
import org.apache.shiro.web.servlet.ShiroFilterFactoryBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class ShiroConfig {

    @Bean
    public AbstractShiroFilter shiroFilterFactoryBean() throws Exception {
        ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
        shiroFilterFactoryBean.setSecurityManager(securityManager());
        shiroFilterFactoryBean.setLoginUrl("/login");
        shiroFilterFactoryBean.setSuccessUrl("/home");
        shiroFilterFactoryBean.setUnauthorizedUrl("/unauthorized");

        return shiroFilterFactoryBean;
    }

    @Bean
    public WebSecurityManager securityManager() {
        DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
        securityManager.setSessionManager(sessionManager());
        securityManager.setCacheManager(new MemoryConstrainedCacheManager());

        return securityManager;
    }

    @Bean
    public SessionManager sessionManager() {
        GemFireSessionManager sessionManager = new GemFireSessionManager();
        sessionManager.setSessionDAO(new EnterpriseCacheSessionDAO());

        return sessionManager;
    }
}
  1. 创建一个控制器类,用于处理登录和注销请求:
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.session.Session;
import org.apache.shiro.subject.Subject;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;

@Controller
public class LoginController {

    @GetMapping("/login")
    public String login() {
        return "login";
    }

    @PostMapping("/login")
    public String doLogin(@RequestParam("username") String username,
                          @RequestParam("password") String password,
                          Model model) {
        Subject currentUser = SecurityUtils.getSubject();
        if (!currentUser.isAuthenticated()) {
            UsernamePasswordToken token = new UsernamePasswordToken(username, password);
            token.setRememberMe(true);
            try {
                currentUser.login(token);
            } catch (Exception e) {
                model.addAttribute

相关内容

热门资讯

线上(wepoke真的)原来是... 线上(wepoke真的)原来是真的有挂!其实真的有挂(2022已更新)(哔哩哔哩);亲,其实确实真的...
两教程(Wepoke程序)软件... 两教程(Wepoke程序)软件透明挂辅助工具(软件透明挂)透视辅助(2024已更新)(哔哩哔哩);致...
软件(wepoke透明)原来是... 软件(wepoke透明)原来是真的有挂!其实真的有挂(2020已更新)(哔哩哔哩)是一款可以让一直输...
一模拟器(德扑工具)外挂辅助工... 一模拟器(德扑工具)外挂辅助工具(透视)透视辅助(2025已更新)(哔哩哔哩);亲真的是有正版授权,...
系统(aapoker讲解)竟然... 系统(aapoker讲解)竟然真的有挂!其实真的有挂(2021已更新)(哔哩哔哩);aapoker讲...
6系统(aapoker下载)外... 6系统(aapoker下载)外挂辅助工具(辅助挂)透视辅助(2023已更新)(哔哩哔哩)aapoke...
智能(德扑之星刷数据)果真真的... 智能(德扑之星刷数据)果真真的有挂!原来真的有挂(2025已更新)(哔哩哔哩);《WPK辅助透视》‌...
1机器人(德州nzt软件)软件... 1机器人(德州nzt软件)软件透明挂辅助软件(透视)透视辅助(2022已更新)(哔哩哔哩);人气非常...
ai代打(德扑之星决策)确实是... ai代打(德扑之星决策)确实是真的有挂!原来真的有挂(2020已更新)(哔哩哔哩);科技详细教程小薇...
第8透明(wepoke数据)外... 第8透明(wepoke数据)外挂透明挂辅助神器(辅助挂)透视辅助(2023已更新)(哔哩哔哩);原来...