Spring+ Spring cloud + SSO單點登陸應用認證

以前的文章中有介紹spring cloud sso集成的方案,也作過spring + jwt + redis的解決方案,不一樣系統的無縫隙集成,統一的sso單點登陸界面的管理、每一個應用集成的權限認證,白名單等都是咱們須要考慮的,如今針對於以上的問題咱們作了sso單點登陸應用認證平臺,設計以下:html

1. 數據庫設計:java

Java代碼 複製代碼 收藏代碼redis

  1. DROP TABLE IF EXISTS `sso_app_apply`;  
  2. CREATE TABLE `sso_app_apply` (  
  3.   `id` varchar(200) NOT NULL COMMENT '編號',  
  4.   `type` varchar(200) NOT NULL COMMENT '所屬分類',  
  5.   `applicant` varchar(200) NOT NULL COMMENT '申請人',  
  6.   `approver` varchar(200) NOT NULL COMMENT '審批人',  
  7.   `appname` varchar(200) NOT NULL COMMENT '應用名稱',  
  8.   `range` varchar(200) NOT NULL COMMENT '使用範圍',  
  9.   `token` varchar(200) NOT NULL COMMENT 'token認證碼',  
  10.   `approval_time` datetime NOT NULL COMMENT '審批時間',  
  11.   `create_date` datetime NOT NULL COMMENT '建立時間',  
  12.   `update_by` varchar(64) NOT NULL COMMENT '更新者',  
  13.   `update_date` datetime NOT NULL COMMENT '更新時間',  
  14.   `del_flag` char(1) NOT NULL DEFAULT '0' COMMENT '刪除標記',  
  15.   `status` char(1) DEFAULT '0' COMMENT '審覈狀態:0(待審覈) 1(審覈經過) 2(駁回) 3(黑名單)',  
  16.   PRIMARY KEY (`id`)  
  17. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso應用申請表';  

[java] view plain copy print?spring

  1. DROP TABLE IF EXISTS `sso_app_apply`;  
  2. CREATE TABLE `sso_app_apply` (  
  3.   `id` varchar(200) NOT NULL COMMENT '編號',  
  4.   `type` varchar(200) NOT NULL COMMENT '所屬分類',  
  5.   `applicant` varchar(200) NOT NULL COMMENT '申請人',  
  6.   `approver` varchar(200) NOT NULL COMMENT '審批人',  
  7.   `appname` varchar(200) NOT NULL COMMENT '應用名稱',  
  8.   `range` varchar(200) NOT NULL COMMENT '使用範圍',  
  9.   `token` varchar(200) NOT NULL COMMENT 'token認證碼',  
  10.   `approval_time` datetime NOT NULL COMMENT '審批時間',  
  11.   `create_date` datetime NOT NULL COMMENT '建立時間',  
  12.   `update_by` varchar(64) NOT NULL COMMENT '更新者',  
  13.   `update_date` datetime NOT NULL COMMENT '更新時間',  
  14.   `del_flag` char(1) NOT NULL DEFAULT '0' COMMENT '刪除標記',  
  15.   `status` char(1) DEFAULT '0' COMMENT '審覈狀態:0(待審覈) 1(審覈經過) 2(駁回) 3(黑名單)',  
  16.   PRIMARY KEY (`id`)  
  17. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso應用申請表';  
DROP TABLE IF EXISTS `sso_app_apply`;
CREATE TABLE `sso_app_apply` (
  `id` varchar(200) NOT NULL COMMENT '編號',
  `type` varchar(200) NOT NULL COMMENT '所屬分類',
  `applicant` varchar(200) NOT NULL COMMENT '申請人',
  `approver` varchar(200) NOT NULL COMMENT '審批人',
  `appname` varchar(200) NOT NULL COMMENT '應用名稱',
  `range` varchar(200) NOT NULL COMMENT '使用範圍',
  `token` varchar(200) NOT NULL COMMENT 'token認證碼',
  `approval_time` datetime NOT NULL COMMENT '審批時間',
  `create_date` datetime NOT NULL COMMENT '建立時間',
  `update_by` varchar(64) NOT NULL COMMENT '更新者',
  `update_date` datetime NOT NULL COMMENT '更新時間',
  `del_flag` char(1) NOT NULL DEFAULT '0' COMMENT '刪除標記',
  `status` char(1) DEFAULT '0' COMMENT '審覈狀態:0(待審覈) 1(審覈經過) 2(駁回) 3(黑名單)',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso應用申請表';

 

Java代碼 複製代碼 收藏代碼數據庫

  1. DROP TABLE IF EXISTS `sso_app_template`;  
  2. CREATE TABLE `sso_app_template` (  
  3.   `id` varchar(200) NOT NULL COMMENT '編號',  
  4.   `a_id` varchar(200) NOT NULL COMMENT '應用id',  
  5.   `t_id` varchar(200) NOT NULL COMMENT '模板id',  
  6.   PRIMARY KEY (`id`)  
  7. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso應用模板中間表';  

[java] view plain copy print?app

  1. DROP TABLE IF EXISTS `sso_app_template`;  
  2. CREATE TABLE `sso_app_template` (  
  3.   `id` varchar(200) NOT NULL COMMENT '編號',  
  4.   `a_id` varchar(200) NOT NULL COMMENT '應用id',  
  5.   `t_id` varchar(200) NOT NULL COMMENT '模板id',  
  6.   PRIMARY KEY (`id`)  
  7. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso應用模板中間表';  
DROP TABLE IF EXISTS `sso_app_template`;
CREATE TABLE `sso_app_template` (
  `id` varchar(200) NOT NULL COMMENT '編號',
  `a_id` varchar(200) NOT NULL COMMENT '應用id',
  `t_id` varchar(200) NOT NULL COMMENT '模板id',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso應用模板中間表';

 

Java代碼 複製代碼 收藏代碼框架

  1. DROP TABLE IF EXISTS `sso_template`;  
  2. CREATE TABLE `sso_template` (  
  3.   `id` varchar(200) NOT NULL COMMENT '編號',  
  4.   `name` varchar(200) NOT NULL COMMENT '模板名稱',  
  5.   `type` varchar(200) NOT NULL COMMENT '模板分類',  
  6.   `img` varchar(200) NOT NULL COMMENT '模板圖片',  
  7.   `create_by` varchar(64) NOT NULL COMMENT '建立者',  
  8.   `create_date` datetime NOT NULL COMMENT '建立時間',  
  9.   `update_by` varchar(64) NOT NULL COMMENT '更新者',  
  10.   `update_date` datetime NOT NULL COMMENT '更新時間',  
  11.   PRIMARY KEY (`id`)  
  12. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso模板表';  

[java] view plain copy print?數據庫設計

  1. DROP TABLE IF EXISTS `sso_template`;  
  2. CREATE TABLE `sso_template` (  
  3.   `id` varchar(200) NOT NULL COMMENT '編號',  
  4.   `name` varchar(200) NOT NULL COMMENT '模板名稱',  
  5.   `type` varchar(200) NOT NULL COMMENT '模板分類',  
  6.   `img` varchar(200) NOT NULL COMMENT '模板圖片',  
  7.   `create_by` varchar(64) NOT NULL COMMENT '建立者',  
  8.   `create_date` datetime NOT NULL COMMENT '建立時間',  
  9.   `update_by` varchar(64) NOT NULL COMMENT '更新者',  
  10.   `update_date` datetime NOT NULL COMMENT '更新時間',  
  11.   PRIMARY KEY (`id`)  
  12. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso模板表';  
DROP TABLE IF EXISTS `sso_template`;
CREATE TABLE `sso_template` (
  `id` varchar(200) NOT NULL COMMENT '編號',
  `name` varchar(200) NOT NULL COMMENT '模板名稱',
  `type` varchar(200) NOT NULL COMMENT '模板分類',
  `img` varchar(200) NOT NULL COMMENT '模板圖片',
  `create_by` varchar(64) NOT NULL COMMENT '建立者',
  `create_date` datetime NOT NULL COMMENT '建立時間',
  `update_by` varchar(64) NOT NULL COMMENT '更新者',
  `update_date` datetime NOT NULL COMMENT '更新時間',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='sso模板表';

 

2. 執行流程分佈式

A. 成用戶註冊 (能夠註冊我的帳戶或者企業帳戶)   加密

B.  申請應用(多是多個應用),選擇不一樣的模板(不一樣模板對應不一樣行業的sso單點登陸系統)

C.  管理人員進行應用審覈(申請人提交信息的審覈),審覈經過之後經過加密方式生成應用對應的token信息

D.  後臺管理(應用列表、應用審覈、模板管理等)

E. 將token信息和應用信息傳遞,進行sso統一攔截器認證(驗證白名單)

F. 成功or失敗(跳轉到指定模板的sso登陸界面)

 

3. 效果界面:



 

 

願意瞭解框架技術或者源碼的朋友直接求求交流分享技術:3133806896


分佈式的一些解決方案,有願意瞭解的朋友能夠找咱們團隊探討


更多詳細源碼參考來源

相關文章
相關標籤/搜索