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

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

关于单点登录(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思源笔记

    1083 引用 • 3461 回帖 • 261 关注

相关帖子

欢迎来到这里!

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

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

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

  • 其他回帖
  • someone

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

  • someone

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

  • someone756 1 赞同

推荐标签 标签

  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 12 关注
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    25 引用 • 83 回帖
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    14 引用 • 7 回帖
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    186 引用 • 318 回帖 • 336 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    106 引用 • 152 回帖
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    51 引用 • 226 回帖
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    332 引用 • 619 回帖
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖
  • Tomcat

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

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

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

    14 引用 • 42 回帖 • 705 关注
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 60 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖 • 2 关注
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 553 关注
  • 安全

    安全永远都不是一个小问题。

    191 引用 • 813 回帖
  • 反馈

    Communication channel for makers and users.

    124 引用 • 907 回帖 • 210 关注
  • API

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

    76 引用 • 429 回帖 • 1 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 232 回帖 • 1 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 83 关注
  • 笔记

    好记性不如烂笔头。

    306 引用 • 782 回帖
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    131 引用 • 1114 回帖 • 138 关注
  • JWT

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

    20 引用 • 15 回帖 • 20 关注
  • 脑图

    脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。

    21 引用 • 58 回帖
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 53 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    207 引用 • 2031 回帖
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    54 引用 • 85 回帖
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1425 引用 • 10043 回帖 • 474 关注