【转】cas注册后自动登录

简介:

1. 关于CAS的介绍不再累述,我想涉及过SSO同学应该都会对该框架所有了解,我们目前项目采用的CAS Server 版本为 3.4.2.1, 其 CAS Client 版本为 3.1.10。 
         CAS项目官方:http://www.jasig.org/cas 
         本文讲述CAS登录处理未包括 CAS Client 与 Server 端的对 ST 采用SMAL验证的流程。 

     2. 对于登录其主要处理流程: 
         注册成功后 -> 调用CAS登录处理的相关模块 -> 验证用户名密码 -> 生成TGT -> 生成TG -> Add ST&TGT至相关Register类 -> Add TGT至Cookie -> 重定向至 cas/login URL -> 完成 

     3.  CAS 登录处理主要模块(类): 
              a. Credentials  用于存储用户登录认证信息接口。 
                  其默认实现类:org.jasig.cas.authentication.principal.UsernamePasswordCredentials 
              b. CentralAuthenticationService 用于生成 ST(Service Ticket) 和  TGT(TicketGrantingTicket)的认证服务类。 
                  其默认实现类: org.jasig.cas.CentralAuthenticationServiceImpl 
              c. CookieRetrievingCookieGenerator 用于将TGT添加至Cookie及对Cookie进行管理。 

     4.  具体实现代码: 

复制代码
/** 
 * user register process and automatic login. 
 * @param userForm the user information object. 
 * @param request  the HttpServletRequest object 
 * @param response the HttpServletResponse object 
 * @return get result view 
 */  
protected ModelAndView handleUserRegisterInternal(UserInfoVo userForm, HttpServletRequest request, HttpServletResponse response) {  
      
    ModelAndView signinView = new ModelAndView(REGISTER_VIEW);;  
    final boolean isUnique = userService.checkUserUnique(userForm.getLoginName());  
    final boolean isRegistered = isUnique ? registerUser(userForm, request, response) : false;  
  
    if (isRegistered) {  
        bindTicketGrantingTicket(userForm.getLoginName(), userForm.getLoginPassword(), request, response);  
        signinView.setViewName(getSignInView(request));  
    }  
    return signinView;  
}  
复制代码
复制代码
/** 
 * Invoke generate validate Tickets and add the TGT to cookie. 
 * @param loginName     the user login name. 
 * @param loginPassword the user login password. 
 * @param request       the HttpServletRequest object. 
 * @param response      the HttpServletResponse object. 
 */  
protected void bindTicketGrantingTicket(String loginName, String loginPassword, HttpServletRequest request, HttpServletResponse response){  
    try {  
        UsernamePasswordCredentials credentials = new UsernamePasswordCredentials();  
        credentials.setUsername(loginName);  
        credentials.setPassword(loginPassword);  
        String ticketGrantingTicket = centralAuthenticationService.createTicketGrantingTicket(credentials);  
        ticketGrantingTicketCookieGenerator.addCookie(request, response, ticketGrantingTicket);  
    } catch (TicketException te) {  
        logger.error("Validate the login name " + loginName + " failure, can't bind the TGT!", te);  
    } catch (Exception e){  
        logger.error("bindTicketGrantingTicket has exception.", e);  
    }  
}  
复制代码
复制代码
/** 
 * Get the signIn view URL. 
 * @param request the HttpServletRequest object. 
 * @return redirect URL 
 */  
protected String getSignInView(HttpServletRequest request) {  
    String service = ServletRequestUtils.getStringParameter(request, "service", "");  
    return ("redirect:login" + (service.length() > 0 ? "?service=" + service : ""));  
}
复制代码

 cas-servlet.xml 相关代码: 

<bean id="registerController" class="com.xxxxx.sso.web.RegisterController"   
    p:userService-ref="userService"  
    p:validator-ref="registerValidator"  
    p:centralAuthenticationService-ref="centralAuthenticationService"  
    p:ticketGrantingTicketCookieGenerator-ref="ticketGrantingTicketCookieGenerator"/>  

  注: 关于centralAuthenticationService及ticketGrantingTicketCookieGenerator已声明在 spring-configuration/applicationContext.xml 和 ticketGrantingTicketCookieGenerator.xml中 






本文转自秋楓博客园博客,原文链接:http://www.cnblogs.com/rwxwsblog/p/5156244.html,如需转载请自行联系原作者
目录
相关文章
|
应用服务中间件 nginx
|
2月前
cas → 注销登录后跳转到登录页
cas → 注销登录后跳转到登录页
|
3月前
|
SQL 数据安全/隐私保护
带token的多用户登录(注册直接粗暴解决)
带token的多用户登录(注册直接粗暴解决)
带token的多用户登录(注册直接粗暴解决)
|
8月前
|
安全 搜索推荐 Java
SpringSecurity-8-自动登录和注销功能实现
当我们在登录某一个网站的时候,我们会使用账号密码进行登录,但是我们不想每一次关闭浏览器,我们不想每一次重新输入账号和密码,贴合用户的登录体验,给用户带来方便,我们使用自动登录功能,将登录信息保存在浏览器的cookie中,这样用户在下次访问的时候,自动实现校验并新建登录状态。但是这样也会给用户带来信息泄露的危险。
92 0
|
前端开发 数据安全/隐私保护 UED
|
JavaScript 前端开发 Java
单点登录CAS4-服务端登录页添加验证码
1、由于CAS使用了SpringWebFlow,所以我们想在登录页表单中增加属性就直接找\WEB-INF\login-webflow.
1958 0
|
XML 前端开发 Java
单点登录CAS系列8-客户端配置单点登出
原理 本文内容包括配置单点登出、登出后自动跳转指定资源、CASServer禁用单点登出等 与单点登录相对应:登录的地址是/login,登出的地址是/logout,这里需要配置下面两个Filter SingleSi...
995 0
|
Java 数据格式 XML
单点登录CAS6-服务端自定义返回的用户信息
原理 返回的用户信息是在deployerConfigContext.xml中的配置的 既然想自定义返回的用户信息,那么继承org.
1579 0
|
Web App开发 XML Java
单点登录CAS7-客户端配置单点登录
原理 这里用的是:cas-client-core-3.4.0.jar(2015-07-21发布的) 下载地址为:http://mvnrepository.
972 0
|
前端开发 JavaScript
单点登录CAS9-服务端RememberMe
CAS一些配置项 下面是CAS-4.0.3服务端的来自cas.properties中的一些配置项介绍 1、cas.securityContext.
1059 0