《SSO系列二》自己动手写一个SSO

2024-06-14 09:48
文章标签 系列 动手 sso

本文主要是介绍《SSO系列二》自己动手写一个SSO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

上篇博客http://blog.csdn.net/bingospunky中大概的介绍了一下SSO。这篇文章介绍一个我学习过程中写的一个Demo,可以让初学者对SSO有一个整体的认识。

线上演示

我已经把我这个Demo部署在我的服务器上,你可以按照如下步骤体验。(需要翻墙)

1.两个业务的地址分别是
http://taobao.mabinbin.com/bzi1/user/index
http://tmall.mabinbin.com/bzi2/user/index
登录这两个地址都会跳转到SSO的登录界面。

2.在http://taobao.mabinbin.com/bzi1/user/index那个界面跳转的SSO登录界面登录,然后可以跳转到http://taobao.mabinbin.com/bzi1/user/index这个网站,然后再开一个浏览器访问http://tmall.mabinbin.com/bzi2/user/index,可以不用登录,访问到http://tmall.mabinbin.com/bzi2/user/index的内容。这样就实现了单点登录。

3.这个Demo的接口在http://sso.mabinbin.com/sso/swagger/index.html这里。

源码下载,编译运行

项目源码在http://mabinbin.com:8888/binbincivil/sso-demo这里。

1.git clone http://www.mabinbin.com:8888/binbincivil/sso-demo.git
2.在本地启动redis,host:127.0.0.1 port:6379 不要密码
3.cd sso-demo-home, mvn clean install
4.不部署项目。
4.1.把sso-server项目部署在localhost:8080下,不论用ide还是使用脚本+插件,保证项目在localhost:8080下,且没有contextPath下可以访问,关键注意没有contextPath。
4.2.把sso-bzi-8081部署两个,分别在localhost:8081localhost:8082,这里也注意没有contextPath。
建议使用IDEA,部署服务器参照最后的截图。
5.修改本地hosts,添加如下解析:

127.0.0.1 feifei1.com
127.0.0.1 feifei2.com

6.两个业务服务的地址分别的http://feifei1.com:8081/user/index、http://feifei2.com:8082/user/index,接口swagger的地址为http://localhost:8080/swagger/index.html。
7.使用步骤参考上述的线上演示部分。

代码介绍

1.项目通过maven构建,有三个子项目,分别是sso-server,sso-client,sso-bzi-8081。sso-server是一个war项目,负责用户的登录、登录、注册等功能,提供restful接口供业务服务器验证Token有效性和获取用户信息。sso-client是一个jar项目,用来让各个业务服务器集成,来获取SSO的能力。该jar对请求进行过滤,如果需要登录,则跳转到SSO的登录界面,如果是登录后的,它会使用Token去SSO服务器验证登录信息。sso-bzi-8081是一个模拟的业务服务,通过依赖sso-client来用户使用SSO的能力。
2.该Demo的用户信息存放在redis里,在sso-server项目里Spring加载结束的时候,会添加一个默认的用户:账号:10000密码123456,该Demo只演示单点登录功能,没有实现用户的注册、修改信息等一些其他功能。对于登出,可以登出,但是没有做单点。
3.本着少添加依赖的原则,sso-server项目使用spring-mvc、redis。sso-bzi-8081直接基于servlet。
4.代码通过git管理,可以方便的看到commit记录。
5.上面一节中,需要严格按照步骤把redis设置成那个样子,项目部署也要在指定的端口和contextPath下。这些都可以在项目中进行设置,现在默认的设置就是这个样子的。如果需要这些都可以改。

实现原理

1.当用户访问http://feifei1.com:8081/user/index时,请求会被过滤器net.qingtian.client.filter.SSOFilter拦截,在SSOFilter里进行判断,因为没有在8081这个项目登录过,所以直接跳转到SSO的登录界面http://localhost:8080/resources/login.html?returnURL=http%3A%2F%2Ffeifei1.com%3A8081%2Fuser%2Findex进行登录。
2.登录成功后,服务器会给加一个如下的Cookie,实现下次自动登录。

Set-Cookie:CCC=01ca02d2-c5f8-44b8-bc5a-824af99f6796; Expires=Wed, 29-Nov-2017 07:42:38 GMT; Path=/

3.登录成功后,同时服务器端生成一个Token字符串,可以通过这个字符串对应到这个用户。服务器把这个Token返回给SSO登录的界面。登录界面的js收到这个token后,会执行页面跳转,跳转到第一步中的业务地址,并携带这个token。跳转的地址如下

http://feifei1.com:8081/user/index?token=01ca02d2-c5f8-44b8-bc5a-824af99f6796

4.请求还是会被过滤器net.qingtian.client.filter.SSOFilter拦截,在SSOFilter里判断,这个用户没有在8081这个项目登录过,但是请求里包含token,SSOFilter会调用SSO的restful接口验证token的有效性,如果token是有效的,那么可以获取到用户的基本信息,然后把这些基本信息存放在session里来标记用户在8081这个项目里已经登录。

项目在IDEA的部署配置

sso-server:

http://p049fjos5.bkt.clouddn.com/sso-server-1.jpg
http://p049fjos5.bkt.clouddn.com/sso-server-2.jpg

sso-bzi-8081:

http://p049fjos5.bkt.clouddn.com/sso-bzi-8081-1.jpg
http://p049fjos5.bkt.clouddn.com/sso-bzi-8081-2.jpg

sso-bzi-8082:

http://p049fjos5.bkt.clouddn.com/sso-bzi-8082-1.jpg
http://p049fjos5.bkt.clouddn.com/sso-bzi-8082-2.jpg

这篇关于《SSO系列二》自己动手写一个SSO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1060067

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

GPT系列之:GPT-1,GPT-2,GPT-3详细解读

一、GPT1 论文:Improving Language Understanding by Generative Pre-Training 链接:https://cdn.openai.com/research-covers/languageunsupervised/language_understanding_paper.pdf 启发点:生成loss和微调loss同时作用,让下游任务来适应预训

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

Java基础回顾系列-第七天-高级编程之IO

Java基础回顾系列-第七天-高级编程之IO 文件操作字节流与字符流OutputStream字节输出流FileOutputStream InputStream字节输入流FileInputStream Writer字符输出流FileWriter Reader字符输入流字节流与字符流的区别转换流InputStreamReaderOutputStreamWriter 文件复制 字符编码内存操作流(

Java基础回顾系列-第五天-高级编程之API类库

Java基础回顾系列-第五天-高级编程之API类库 Java基础类库StringBufferStringBuilderStringCharSequence接口AutoCloseable接口RuntimeSystemCleaner对象克隆 数字操作类Math数学计算类Random随机数生成类BigInteger/BigDecimal大数字操作类 日期操作类DateSimpleDateForma

Java基础回顾系列-第三天-Lambda表达式

Java基础回顾系列-第三天-Lambda表达式 Lambda表达式方法引用引用静态方法引用实例化对象的方法引用特定类型的方法引用构造方法 内建函数式接口Function基础接口DoubleToIntFunction 类型转换接口Consumer消费型函数式接口Supplier供给型函数式接口Predicate断言型函数式接口 Stream API 该篇博文需重点了解:内建函数式

Java基础回顾系列-第二天-面向对象编程

面向对象编程 Java类核心开发结构面向对象封装继承多态 抽象类abstract接口interface抽象类与接口的区别深入分析类与对象内存分析 继承extends重写(Override)与重载(Overload)重写(Override)重载(Overload)重写与重载之间的区别总结 this关键字static关键字static变量static方法static代码块 代码块String类特