sso单点登录(cas)

sso单点登录(cas)

在这里插入图片描述

本文主要讲解这个图具体实现
整体将以游乐园为例子讲解

WebBrowser我们将其称为游客
CASclient我们将其称为过山车
CASServer我们将其称为售票处

1.首先游客到达了过山车,过山车询问并验证其票据
如果票据验证通过即可游玩,没有或者不通过进行第2步。

2.游客票不正确,过山车告诉游客去售票处买票。接下来游客带着自己的信息过去,进行第3步。

3.游客将相关物品给售票处,售票处检验。正确到第4步。

4.检验正确,售票处将告诉游客过山车地址以及给予票据。之后第5步。

5.游客带着票过来,过山车处去找售票处验证。

6.检测成功或者失败

//总体思路 1 游客过来买票 检测有票并且检测成功带着信息访问
//		  2 游客没有买票 那么直接让去买票或有票是张假票再让去买
@Controller
@RequestMapping("/api/open/sso")
public class SsoCasController {

	private final Log log = LogFactory.getLog(this.getClass());

	/**
	 * cas服务器地址
	 */
	@Value("${cas.casBasePath}")
	private String casBasePath;

	@GetMapping("/login")
	public void ssoLogin(HttpServletRequest request, HttpServletResponse response) {
		try {
		
			// CAS票据验证地址
			String casValidateUrl = casBasePath + "/serviceValidate";
			// CAS登录地址
			String casLoginUrl = casBasePath + "/login";
			// CAS注销地址
			String casLogoutUrl = casBasePath + "/logout";
			
			//到游乐园了检票,存在票
			if (CasUtils.hasTicket(request)) {
			
				//获取service
				String targetUrl = CasUtils.getTargetUrl(request);
				//得到票据信息
				LoginUser loginUser = CasUtils.getLoginUser(request, casValidateUrl);
				
				//售卖处检票
				//account != null && account.length() != 0 
				if (loginUser.isLogin()) {
					String url = null;
					if(targetUrl.contains("?")){
						url = targetUrl + "&t="+ DateUtil.currentSeconds()+"&account=" + loginUser.getAccount();
					}else{
						url = targetUrl + "?t="+ DateUtil.currentSeconds()+"&account=" + loginUser.getAccount();
					}
					response.sendRedirect(url);
					//空票
				} else {
					//不存在用户信息那么游客去买票
					log.error("单点登陆失败==========");
					response.setContentType("text/html;charset=utf-8");
					response.getWriter().write("<script>alert('本系统没有此账户或票据验证失败!');</script>");
					response.getWriter().flush();
				}
			} else {
				//游客没票
				String loginUrl = CasUtils.getLoginUrl(request, casLoginUrl);
				response.sendRedirect(loginUrl);
			}
		} catch (Exception e) {
			log.error("单点登陆失败,错误信息={}"+ e.toString());
		}

	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SSO(Single Sign-On)单点登录是一种身份验证和授权机制,允许用户使用一组凭据(例如用户名和密码)登录到多个应用程序或系统中,而无需为每个应用程序重新输入凭据。 在Java中实现SSO单点登录,可以使用一些开源的框架和技术,如Spring Security、CAS(Central Authentication Service)等。 下面是一个简单的SSO单点登录Java实现步骤: 1. 配置认证中心(Identity Provider):搭建一个独立的认证中心,负责处理用户的身份验证和授权。可以使用Spring Security框架来实现认证中心。 2. 配置服务提供者(Service Provider):在每个需要接入SSO的应用程序中,配置服务提供者,使其能够与认证中心进行通信。可以使用CAS来实现服务提供者。 3. 配置认证中心和服务提供者之间的信任关系:认证中心和服务提供者之间需要建立信任关系,以确保安全性和可靠性。可以通过在认证中心和服务提供者之间共享密钥、证书等方式来实现。 4. 实现登录页面:在服务提供者的登录页面上,添加一个登录按钮或链接,点击后将用户重定向到认证中心的登录页面。 5. 用户身份验证:用户在认证中心的登录页面上输入用户名和密码后,认证中心进行身份验证,并生成一个令牌(Token)。 6. 单点登录:认证中心将令牌返回给服务提供者,服务提供者使用该令牌进行身份验证,验证通过后,用户将被允许访问服务提供者的应用程序。 7. 单点注销:当用户在一个应用程序中注销登录时,认证中心会收到注销请求,并将该注销请求广播给所有其他已登录的应用程序,从而实现单点注销。 以上是一个简单的SSO单点登录Java实现步骤,具体的实现方式可以根据具体的框架和技术进行调整和扩展。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值