java sso 单点登录 (方式之一 比较简单的方式)

本贴最后更新于 2634 天前,其中的信息可能已经水流花落

关于单点登录(Single Sign On)

概念性的东西,谷歌百度上很多资料,我这里就不详细讲了,[附上百科链接](https://baike.baidu.com/item/SSO/3451380),SSO的实现

网上也能找到一大堆资料。起初我是为了实现系统的保持登录状态,而了解到这个sso,单点登录应该会是很多系统都必须用到的一个模块,

对于每一个程序员来说,这个是必须会的技能。单点登录也有很多层次的实现,我这里就简单讲一下一个基于cookie的在同一个顶级域名下

子系统之间的sso实现原理。

关于 cookie

cookie的定义,功能我在这里不在叙述,也可以在谷歌百度上找到相关资料。在这里我主要想提到cookie的存储,维基百科上提到:按在客

户端中的存储位置,可分为内存Cookie和硬盘Cookie。内存Cookie由浏览器维护,保存在内存中,浏览器关闭后就消失了,其存在时间是短

暂的。硬盘Cookie保存在硬盘里,有一个过期时间,除非用户手工清理或到了过期时间,硬盘Cookie不会被删除,其存在时间是长期的。所以,

按存在时间,可分为非持久Cookie和持久Cookie。

在本文提到的sso实现方式中,cookie是这个实现的桥梁,是唯一的验证token。所以cookie只要拿到手,就等于有了权限,为了防止别人伪造,

这个有权限的cookie是需要加密的。而加密解密都需要在后台完成。

实现步骤

1、 用户登录,完成权限认证后,产生一个唯一的ssokey,String ssokey = des.encrypt(RANDOM.nextInt(999999) + "|" + user_id + "|" + RANDOM.nextInt(999999));

   参数解析:这个user_id 可以是其他,但是最好可以跟你的当前登录用户建立起联系。这个ssokey必须是唯一的。

2、 把ssokey写入cookie,CookieUtil.set(response, domainName, cookieName, ssokey, keepLogin ? ssoCookieMaxage : -1, false);

   参数解析:
  
   domainName:共享cookie的域名,一般用顶级域名,比如我的   .huiyanxian.cn ,那么cookie在此域名底下是共享的。
  
   cookieName:cookie的名字,可以自定义,最好跟cookie的用途相关来命名
   
   ssokey:唯一的token,校验的证书
   
   keepLogin:顾名思义,是否保持登录,是的话,写入cookie存在时间ssoCookieMaxage,如果不保持登录,则写入-1,cookie将在浏览器退出后删除。
   
   false:是否加密,因为我在产生ssokey的时候已经加密过了,所以这里就不加密了 。
   
   cookie每个人的封装习惯不一样,我只是按照我的个人封装来讲解,如果你需要封装,可以按照自己的业务,或者代码习惯来。
   
3、 再一次登录,或者子系统sso登录,首先查看是否有登录的session,如果没有,在看看是否有ssokey 的cookie,如果没有,跳转去sso系统登录。

   登录之后,ssokey的cookie就存在了,携带ssokey请求sso服务器api,sso服务器通过这个cookie过来的ssokey,解密,拿到里面存在的user_id,
   
   然后查询数据库取得登录的用户信息返回给子系统。 贴上子系统获取登录用户信息代码:
   
   public static Object getLoginUser(HttpServletRequest request) {
		User user = null;
		try {
			String ssokey = CookieUtil.get(request, cookieName);
			if (StringUtils.isEmpty(ssokey)) {
				ssokey = (String) request.getAttribute("ssokey");
			}
			user = (User) request.getSession().getAttribute("loginUser");
			if (user != null) {
				return user;
			}
			if (!StringUtils.isEmpty(ssokey)) {
				String url = ssoRemoteUrl + "?ssokey=" + ssokey;
				String result = HttpUtils.get(url, "UTF-8");
				if (!StringUtils.isEmpty(result)) {
					ObjectMapper objectMapper = new ObjectMapper();
					user = objectMapper.readValue(result, User.class);
				}
			}
		} catch (Exception e) {
			log.error(e.getMessage(), e);
		}
		return user;
   }


  sso服务端获取登录用户信息代码:
  
	@RequestMapping(value = "/sso/login/getLoginUser")
	public @ResponseBody Object getLoginUser(HttpServletRequest request, HttpServletResponse response, @RequestParam String ssokey) {
		User user = null;
		try {
			if (!StringUtils.isEmpty(ssokey)) {
				int user_id = getUserId(ssokey);
				user = iUserService.selectById(user_id);
				if (user != null) {
					return user;
				}
			}
		} catch (Exception e) {
			log.error(e.getMessage(), e);
		}
		return user;
	}

  sso登录完成。

总结

 1、本应该附上一张流程图,无奈画图功底实在有限,就不丢出来了。本人文字表述或者实现方法可能有缺陷,还请大家指出,实现方法不止一种,这只是本人
 
	  在实现后一个小总结,如若有不正确的地方,还望大家指正,共同学习交流,如果有建议,或者想交流的同学,可以加我QQ:892662026,指出建议交流。
	  
	  大家也可以使用第三方的开源sso插件,比如cas,比如kisso等等。

相关参考链接

[承一个人主页](http://www.cnblogs.com/ywlaker/p/6113927.html)
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3453 回帖 • 202 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • someone756 1 赞同
  • lousyprogram 1 赞同

    SSO 过于简单了,如果存在跨浏览器、跨平台和跨系统等情况没有顾及到。

  • someone

    这个是 开源的博客源码 不是我的 :joy: :joy:

  • someone

    跨系统 也可以的啦 只要是同一个顶级域名下的都可以。这个只是比较简单的实现方式啦:sob: ,主要还是能力不够

推荐标签 标签

  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 537 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 609 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 241 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    25 引用 • 191 回帖 • 16 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 375 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    15 引用 • 122 回帖
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    133 引用 • 189 回帖 • 1 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 1 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    77 引用 • 430 回帖
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    53 引用 • 37 回帖 • 1 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 156 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    198 引用 • 550 回帖 • 3 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 3 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 1 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 673 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    20 引用 • 23 回帖 • 723 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 95 关注
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    2 引用 • 14 回帖
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 476 关注
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 134 关注
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 597 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 764 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    75 引用 • 1737 回帖 • 1 关注
  • 电影

    这是一个不能说的秘密。

    121 引用 • 601 回帖
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    5 引用 • 107 回帖
  • RabbitMQ

    RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

    49 引用 • 60 回帖 • 361 关注