Foxnic-Web 实现单点登录(SSO)

LeeFJ
• 阅读 447

Foxnic-Web 实现单点登录(SSO)

概述

  所谓单点登录(Single Sign On),简称为 SSO,就是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。
  任何系统接入SSO前需要完成两个步骤,
  1、主数据同步: 这些主数据包括组织、账户、权限信息等,从外部系统(可以是MDM、OA、HR等)同步本系统需要的这些数据。
  2、实现SSO跳转页: 门户系统会将令牌传递至当前系统,当前系统需要读取令牌中的内容,在本系统完成账户认证的操作。

组织与账户同步

  在单点登录之前,首先要确保组织节点、账户等信息已经同步到系统中,组织、账户同步可以有很多中方式,这里不再赘述。

TokenReader

  SSO 对接工作的核心是读取令牌(Token)值,并转换为本系统的 userId。Foxnic-Web 已经对SSO集成做了很大的简单化,仅需实现一个 TokenReader 即可,如下代码所示。

import com.github.foxnic.api.transter.Result;
import org.github.foxnic.web.domain.oauth.User;
import org.github.foxnic.web.framework.sso.TokenReader;
import org.github.foxnic.web.language.Language;
import org.github.foxnic.web.proxy.oauth.UserServiceProxy;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

@Component
    public class FoxnicTokenReader extends TokenReader {
        /**
* 从请求中读取账户
* */
        @Override
        public String readUserId(HttpServletRequest request) {
            // 读取token
            String account=request.getParameter("account");
            // 把读取的 token 转换为 userId
            Result<User> userResult = UserServiceProxy.api().getByAccount(account);
            if(userResult.failure()) return null;
            if(userResult.data()==null) return null;
            // 最终返回 userId
            return userResult.data().getId();
        }

        /**
* 从请求中读取用户指定的语言
* */
        @Override
        public Language readLanguage(HttpServletRequest request) {
            return Language.zh_cn;
        }
    }

系统配置

  TokenReader 定义后需要在 YML 文件中的 security.token-resders 指定,可以指定一个,也可以指定多个,若指定多个则按顺序调用。如下图所示:
Foxnic-Web 实现单点登录(SSO)

SSO 跳转

  在 Foxnic-Web 中,sso 跳转也为 /sso-login.html 。针对不同的场景可以指定不同的参数值:
  format :响应方式,可选值包括:html/json。html 通常用于pc端,完成登录后,自动跳转到指定页面。json 方式主要用于移动端等非网页的场合。
  redirect : 指定登录后的跳转页面,format 为 html 时有效,默认为 /index.html

登出与拦截

  如果当前系统集成了单点登录,那么就需要在系统登出后或会话过期时跳转到Portal自己的登录页,而不是当前系统的登录页。此时需要到系统管理下的系统参数设置两个参数:
  system.external.portal.enable:此参数开启时,表示当前系统与外部Portal系统做了集成。
  system.external.portal.loginURL:当 system.external.portal.enable 参数开启时,指定外部门户的登录页面地址。

登录身份识别

  登录身份识别与优先级的定义其实是常规登录中(非SSO)的一个概念,当用户在登录界面的输入框输入时,可能会输入帐号,也可能输入的是手机号、email、工号等。总之,从技术角度讲,账户表本身或任何与账户表有关联关系的表的字段,只要他唯一,就可以用于身份识别。那么,如何确保正确识别呢? Foxnic-Web 使用了身份优先级配置这个特性。
  Foxnic-Web 的常规登录,目前支持 账户ID,账户名称、手机号、工号,这四种,这些以支持的类型在 LoginIdentityType 枚举类型中定义。为了避免识别的冲突,需要在试试时指定他们的优先级,YML 文件如下所示:

Foxnic-Web 实现单点登录(SSO)
  其中,账户ID作为最高优先级无法修改,其它登录身份识别标识可以通过YML文件调整识别的优先级。

相关项目

  https://gitee.com/LeeFJ/foxnic
  https://gitee.com/LeeFJ/foxnic-web
  https://gitee.com/lank/eam
  https://gitee.com/LeeFJ/foxnic-samples

官方文档

  http://foxnicweb.com/docs/doc.html

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
SSO单点登录学习总结(1)——单点登录(SSO)原理解析
SSO的概念:单点登录SSO(SingleSignOn)是身份管理中的一部分。SSO的一种较为通俗的定义是:SSO是指访问同一服务器不同应用中的受保护资源的同一用户,只需要登录一次,即通过一个应用中的安全验证后,再访问其他应用中的受保护资源时,不再需要重新登录验证。SSO的用途:目前的企业应用环境中,往往有很多的应用系统,
【实践篇】基于CAS的单点登录实践之路
上个月我负责的系统SSO升级,对接京东ERP系统,这也让我想起了之前我做过一个单点登录的项目。想来单点登录有很多实现方案,不过最主流的还是基于CAS的方案,所以我也就分享一下我的CAS实践之路。
Wesley13 Wesley13
3年前
SSO单点登录可以自己实现吗?
ERP与SSO的恩怨情仇第10篇用日志记录“开源软件”的诞生赤龙ERP开源地址:点亮星标,感谢支持,与开发者交流kzca2000码云:https://gitee.com/redragon/redragonerp(https://gitee.com/red
Stella981 Stella981
3年前
Spring+ Spring cloud + SSO单点登录应用认证
之前的文章中有介绍springcloudsso集成的方案,也做过springjwtredis的解决方案,不同系统的无缝隙集成,统一的sso单点登录界面的管理、每个应用集成的权限认证,白名单等都是我们需要考虑的,现在针对于以上的问题我们做了sso单点登录应用认证平台,设计如下:1\.数据库设计:Java代码!复制代码(http
Wesley13 Wesley13
3年前
CAS单点登录(一):单点登录与CAS理论介绍
一、什么是单点登录(SSO)  单点登录主要用于多系统集成,即在多个系统中,用户只需要到一个中央服务器登录一次即可访问这些系统中的任何一个,无须多次登录。  单点登录(SingleSignOn),简称为SSO,是目前比较流行的企业业务整合的解决方案之一。SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所
Stella981 Stella981
3年前
Keycloak单点登录
!(https://oscimg.oschina.net/oscnet/82539809f0d749688ef60b10791cebd7.png)登录及身份认证是现代web应用最基本的功能之一,对于企业内部的系统,多个系统往往希望有一套SSO服务对企业用户的登录及身份认证进行统一的管理,提升用户同时使用多个系统的体验,Keycloak正是为此
Easter79 Easter79
3年前
SpringSecurity 整合SpringBoot结合jwt与rsa实现分布式认证授权
基于springsecurity整合springboot实现简单认证授权(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fwww.cnblogs.com%2Fifme%2Fp%2F12184433.html)进行修改实现分布式认证,即我们常说的单点登录,简称SSO,指的是在多应用系统
Stella981 Stella981
3年前
Spring Security 与 OAuth2(客户端)
client(客户端)(改篇文章尚未修改,仅供参考)OAuth2客户端的实现方式没有太多任何规定,可自行编写登录逻辑也可使用OAuth2提供的@EnableOAuth2Sso注解实现单点登录,该注解会添加身份验证过滤器替我们完成所有操作,只需在配置文件里添加授权服务器和资源服务器的配置即可添加配置
Stella981 Stella981
3年前
Django学习之JWT
JWTJsonWebToken,是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准(RFC7519),被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。单点登录(SingleSignOn,以下简称SSO),是指在多系统应用群中登录一个系统,便可在该应用群其他所有系统中得到授权而无需再次登录。
GoCoding GoCoding
1年前
Casdoor 开始
Casdoor是一个基于OAuth2.0/OIDC的中心化的单点登录(SSO)身份验证平台,本文是其安装和运行的实践记录。