forked from fuluteam/fulusso
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
0ecd9d8
commit 55d1225
Showing
71 changed files
with
43,387 additions
and
184 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,25 +1,189 @@ | ||
# 开源项目葫芦藤sso前端项目 | ||
目前包括:登录、注册、找回密码和用户中心四个页面,具体界面如下: | ||
## 背景 | ||
|
||
<img src="./frontend/readme_assets/login.png"> | ||
18年公司准备在技术上进行转型,而公司技术团队是互相独立的,新技术的推动阻力很大。我们需要找到一个切入点。公司的项目很多,而各个系统之间又不互通,导致每套系统都有一套登录体系,给员工和客户都带来极大的不便。那么从登录切入进去无疑最合适,对于各个团队的的技术改造成本也不大。所以我们团队第一个项目就是搭建一套统一登录认证授权系统,那么葫芦藤项目应运而生。 | ||
|
||
<img src="./frontend/readme_assets/register.png"> | ||
## 技术方案 | ||
|
||
<img src="./frontend/readme_assets/reset-ps.png"> | ||
后端框架:.NET Core3.1(后期会推出 .NET 5版本) | ||
|
||
<img src="./frontend/readme_assets/index.png"> | ||
前端框架:rect | ||
|
||
## 一.效果演示 | ||
数据库:mysql(可根据实际情况,自由切换) | ||
|
||
### 1.安装项目依赖包 | ||
中间件:redis | ||
|
||
## 详细功能 | ||
|
||
|
||
|
||
|
||
#### 认证授权服务 | ||
|
||
基于IdentityServer4实现的协议,支持网站、本地应用、移动端、web服务等应用的认证授权逻辑。 | ||
|
||
#### 单点登录登出 | ||
|
||
支持各种类型应用上的单点登录登出。开箱即用的基础用户管理模块,包括:注册、登录、手机验证码、忘记密码等。为了安全考虑,继承了腾讯图形验证码。 | ||
|
||
#### 第三方登录(微信、钉钉) | ||
|
||
完善的第三方登录支持。支持首次登录时绑定已存在用户或注册新用户后,自动绑定。 | ||
|
||
|
||
|
||
|
||
## 如何快速使用 | ||
|
||
#### 1.下载代码 | ||
|
||
clone代码到本地。根目录结构如下: | ||
|
||
data:image/s3,"s3://crabby-images/d2b36/d2b367b5915f939df8fd7499a8d3a5fb605a7eeb" alt="20201103153907" | ||
|
||
其中,backend存放的是后端代码,frontend存放的是前端代码。 | ||
|
||
进入backend目录,使用Visual Studio打开解决方案。目录结构如下: | ||
|
||
data:image/s3,"s3://crabby-images/5aeec/5aeec3ca6411e23345aad86b6cd534d5672e6444" alt="20201103154250" | ||
|
||
#### 2.生成数据库 | ||
|
||
首先在Fulu.Passport.Web中找到appsettings.Development.json文件。编辑数据库连接字符串: | ||
|
||
data:image/s3,"s3://crabby-images/9f8cd/9f8cd6f16d672b6bf1bdc02ebe15517fdf129a6c" alt="20201103155350" | ||
|
||
|
||
打开程序包管理器,切换默认项目为:Fulu.Passport.Web, 如下图所示: | ||
|
||
|
||
data:image/s3,"s3://crabby-images/1c57d/1c57d4ebb3e5e281a8d37e6a75bc017ac75d8df6" alt="20201106111334" | ||
|
||
|
||
然后在程序包管理器中执行如下命令: | ||
|
||
``` | ||
Add-Migration Init | ||
``` | ||
最后执行完成后,再执行如下命令: | ||
``` | ||
update-database | ||
``` | ||
执行完以上操作后,如没有报错,则会创建数据库,并会在Client表中创建一条测试数据,如下图所示: | ||
|
||
data:image/s3,"s3://crabby-images/d6f4c/d6f4ce98dd828be4ecad734e2ca387eb566f822d" alt="20201103160408" | ||
|
||
|
||
|
||
#### 3.按F5启动后端服务 | ||
|
||
注:由于项目中依赖redis来处理缓存,所以正式启动之前,需要将appsettings.Development.json文件里的redis配置改为你自己的。 | ||
|
||
#### 4.启动前端 | ||
|
||
切换目录到frontend,在命令行中执行如下命令: | ||
|
||
``` | ||
npm install | ||
``` | ||
执行完毕后,执行如下命令: | ||
|
||
### 2.运行命令行 | ||
``` | ||
npm run demo | ||
``` | ||
|
||
执行结果如下图所示: | ||
|
||
data:image/s3,"s3://crabby-images/818ba/818ba9a97214a1e3d1d2af1a34a13239754211d9" alt="20201103161300" | ||
|
||
然后通过http://localhost:8080进行访问。界面如下所示: | ||
|
||
data:image/s3,"s3://crabby-images/71ffe/71ffee587e037702d441a57d03a987b6fb6fe9cc" alt="20201103174200" | ||
|
||
至此,前后端服务已启动完毕,一个开箱即用的认证授权服务就完成了。 | ||
|
||
#### 5.新客户端如何快速接入认证服务? | ||
|
||
认证授权服务存在的意义就是提供统一的认证授权入口,有了这个服务后,每个新的客户端应用无需单独开发认证授权模块。下面就来一起看下如何快速将新应用接入到认证授权服务。(*此处以 ASP.NET Core作为示例,其他语言大同小异*)。 | ||
|
||
示例代码在sample文件夹中,如下图所示: | ||
|
||
data:image/s3,"s3://crabby-images/921d8/921d849f442f47e752c5e36984722eb049bf39ce" alt="20201104165955" | ||
|
||
在正式接入之前,必须先申请应用。(此版本未提供应用管理服务)通过在数据库中添加示例信息,如下图所示: | ||
|
||
data:image/s3,"s3://crabby-images/b7d5c/b7d5cdf697a40b36382a6481a8fb61b42e8a7a5c" alt="20201104192124" | ||
|
||
示例sql脚本: | ||
|
||
|
||
``` | ||
INSERT INTO `fulusso`.`client`(`client_secret`, `full_name`, `host_url`, `redirect_uri`, `description`, `enabled`, `id`) VALUES ('14p9ao1gxu4q3sp8ogk8bq4gkct59t9w', '葫芦藤2', 'http://localhost:5003/', 'http://localhost:5003', NULL, 1, UUID()); | ||
``` | ||
其中,redirect_uri参数指的是从认证服务获取code之后,重定向的url。为了开发的方便,我们的认证服务中仅校验回调域名的域名,不会校验完整的地址。比如,你的redirect_uri为http://www.xxx.com/abc/aaa,则数据库中的redirect_uri字段填写http://www.xxx.com即可。 | ||
|
||
应用信息导入到数据库后,在Startup类的ConfigureServices方法中,添加如下代码: | ||
|
||
``` | ||
services.AddServiceAuthorize(o => | ||
{ | ||
o.AllowClientToken = true; | ||
o.AllowUserToken = true; | ||
o.OnClientValidate = false; | ||
o.Authority = "http://localhost:5000"; | ||
o.ValidateAudience = false; | ||
o.ClientId = Configuration["AppSettings:ClientId"]; | ||
o.ClientSecret = Configuration["AppSettings:ClientSecret"]; | ||
}); | ||
``` | ||
注:需添加Fulu.Service.Authorize项目引用,如下图所示: | ||
|
||
data:image/s3,"s3://crabby-images/6d1e2/6d1e2008a8a5743d96456bf762151ac1913ccd01" alt="20201104170401" | ||
|
||
然后在Configure方法中,添加如下代码: | ||
|
||
|
||
``` | ||
app.UseRouting(); | ||
app.UseJwtAuthorize(); | ||
app.UseAuthorization(); | ||
``` | ||
|
||
其中,UseJwtAuthorize是自定义的中间件,为了实现OAuth2.0的授权码的逻辑。 | ||
限于篇幅,具体代码不在此列出。可在代码仓库中查看。 | ||
|
||
到此为止,这个新应用就成功的接入到认证服务了。 | ||
|
||
当未登录的时候,访问此应用的页面会自动跳转到认证服务的login界面。登录之后,会重定向回登录之前的页面。如下图所示: | ||
|
||
data:image/s3,"s3://crabby-images/cf74d/cf74d8db54ee4f78f18123d67e4a40307a126b52" alt="aa" | ||
|
||
|
||
|
||
## 下一版功能规划 | ||
|
||
1.更多的第三方平台的接入(QQ、微博等) | ||
|
||
2.api授权服务 | ||
|
||
3.更安全的二次验证,集成google令牌 | ||
|
||
4.应用管理 | ||
|
||
等等~~~~,尽请期待。 | ||
|
||
## 体验 | ||
|
||
|
||
演示地址:https://account.suuyuu.cn/ | ||
|
||
代码仓库:https://github.com/fuluteam/fulusso | ||
|
||
|
||
|
||
--- | ||
|
||
|
||
### 3.地址访问 | ||
打开浏览器,输入地址:http://127.0.0.1:8080 | ||
#### 如果觉得项目对于有所帮助,欢迎star。您的支持是我们持续更新的动力。 | ||
|
||
## 二.正式部署 | ||
### 1.如果有二次开发项目,请先运行命令:npm release,静态资源位于dist文件夹下 | ||
### 2.同步dist静态资源至服务器 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
{"error":{"css":"/resources/css/error-f2236b86d5-1.0.0.css","js":"/resources/js/error-43ba7b1be5-1.0.0.js"},"index":{"css":"/resources/css/index-9a7151b86e-1.0.0.css","js":"/resources/js/index-43ba7b1be5-1.0.0.js"},"login":{"css":"/resources/css/login-0d75dae610-1.0.0.css","js":"/resources/js/login-43ba7b1be5-1.0.0.js"},"register":{"css":"/resources/css/register-50bd8a5ac7-1.0.0.css","js":"/resources/js/register-43ba7b1be5-1.0.0.js"},"resetPassword":{"css":"/resources/css/resetPassword-3fd4894f62-1.0.0.css","js":"/resources/js/resetPassword-43ba7b1be5-1.0.0.js"},"":{"html":["/error.html","/index.html","/login.html","/register.html","/resetPassword.html"],"ico":"/favicon.ico","css":"/resources/css/0-54358ee49e1.0.0.css","png":["/resources/images/banner-c.png","/resources/images/banner-l.png","/resources/images/banner-r.png","/resources/images/bg.png","/resources/images/logo.png","/resources/images/sprites.png"],"js":["/resources/js/0-fb0139be68-1.0.0.js","/resources/js/1-81f31bca08-1.0.0.js","/resources/js/2-a7a48c47b1-1.0.0.js","/resources/js/3-c59be124bd-1.0.0.js","/resources/js/4-7921437e54-1.0.0.js","/resources/js/5-5af013294f-1.0.0.js","/resources\\js\\RSA.min.js","/resources\\js\\base.dll.js","/resources\\js\\configs.js"]}} | ||
{"bindAccount":{"css":"/resources/css/bindAccount-9a4f223068-1.0.0.css","js":"/resources/js/bindAccount-bdcb04cb17-1.0.0.js"},"error":{"css":"/resources/css/error-268b21bf66-1.0.0.css","js":"/resources/js/error-bdcb04cb17-1.0.0.js"},"index":{"css":"/resources/css/index-76b9001b20-1.0.0.css","js":"/resources/js/index-bdcb04cb17-1.0.0.js"},"login":{"css":"/resources/css/login-826276cbf9-1.0.0.css","js":"/resources/js/login-bdcb04cb17-1.0.0.js"},"register":{"css":"/resources/css/register-c32b104ac0-1.0.0.css","js":"/resources/js/register-bdcb04cb17-1.0.0.js"},"resetPassword":{"css":"/resources/css/resetPassword-cfe670bffe-1.0.0.css","js":"/resources/js/resetPassword-bdcb04cb17-1.0.0.js"},"":{"html":["/bindAccount.html","/error.html","/index.html","/login.html","/register.html","/resetPassword.html"],"ico":"/favicon.ico","css":"/resources/css/0-54358ee49e1.0.0.css","png":["/resources/images/bg.png","/resources/images/dunpai.png","/resources/images/empty-holder.png","/resources/images/top-gb.png"],"js":["/resources/js/0-c12d94aaa0-1.0.0.js","/resources/js/1-aee686563d-1.0.0.js","/resources/js/2-9c0647e66b-1.0.0.js","/resources/js/3-2d33748915-1.0.0.js","/resources/js/4-c9f5cffbaa-1.0.0.js","/resources/js/5-bb0998cb28-1.0.0.js","/resources/js/6-94c03fe369-1.0.0.js","/resources\\js\\RSA.min.js","/resources\\js\\base.dll.js","/resources\\js\\configs.js"]}} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
<!DOCTYPE html><html class="borderbox"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="renderer" content="webkit"><meta http-equiv="Expires" content="0"><meta http-equiv="pragram" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache"><meta name="description" content="葫芦藤安全中心"><meta name="keywords" content="葫芦藤安全中心"><title>葫芦藤安全中心-用户绑定</title><link rel="shortcut icon" href="/favicon.ico"><link href="/resources/css/bindAccount-9a4f223068-1.0.0.css" rel="stylesheet"></head><body><div id="app"></div><script src="./resources/js/configs.js"></script><script src="./resources/js/base.dll.js"></script><script src="/resources/js/bindAccount-bdcb04cb17-1.0.0.js"></script></body><script src="./resources/js/RSA.min.js"></script><script src="https://ssl.captcha.qq.com/TCaptcha.js"></script></html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
<!DOCTYPE html><html class="borderbox"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="renderer" content="webkit"><meta http-equiv="Expires" content="0"><meta http-equiv="pragram" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache"><meta name="description" content="福禄通行证"><meta name="keywords" content="福禄通行证"><title>福禄通行证</title><link rel="shortcut icon" href="/favicon.ico"><link href="/resources/css/error-f2236b86d5-1.0.0.css" rel="stylesheet"></head><body><div id="app"></div><script src="./resources/js/configs.js"></script><script src="./resources/js/base.dll.js"></script><script src="/resources/js/error-43ba7b1be5-1.0.0.js"></script></body><script src="./resources/js/RSA.min.js"></script><script src="https://ssl.captcha.qq.com/TCaptcha.js"></script></html> | ||
<!DOCTYPE html><html class="borderbox"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="renderer" content="webkit"><meta http-equiv="Expires" content="0"><meta http-equiv="pragram" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache"><meta name="description" content="葫芦藤安全中心"><meta name="keywords" content="葫芦藤安全中心"><title>葫芦藤安全中心</title><link rel="shortcut icon" href="/favicon.ico"><link href="/resources/css/error-268b21bf66-1.0.0.css" rel="stylesheet"></head><body><div id="app"></div><script src="./resources/js/configs.js"></script><script src="./resources/js/base.dll.js"></script><script src="/resources/js/error-bdcb04cb17-1.0.0.js"></script></body><script src="./resources/js/RSA.min.js"></script><script src="https://ssl.captcha.qq.com/TCaptcha.js"></script></html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
<!DOCTYPE html><html class="borderbox"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="renderer" content="webkit"><meta http-equiv="Expires" content="0"><meta http-equiv="pragram" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache"><meta name="description" content="福禄通行证"><meta name="keywords" content="福禄通行证"><title>福禄通行证-安全中心</title><link rel="shortcut icon" href="/favicon.ico"><link href="/resources/css/index-9a7151b86e-1.0.0.css" rel="stylesheet"></head><body><div id="app"></div><script src="./resources/js/configs.js"></script><script src="./resources/js/base.dll.js"></script><script src="/resources/js/index-43ba7b1be5-1.0.0.js"></script></body><script src="./resources/js/RSA.min.js"></script><script src="https://ssl.captcha.qq.com/TCaptcha.js"></script></html> | ||
<!DOCTYPE html><html class="borderbox"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="renderer" content="webkit"><meta http-equiv="Expires" content="0"><meta http-equiv="pragram" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache"><meta name="description" content="葫芦藤安全中心"><meta name="keywords" content="葫芦藤安全中心"><title>葫芦藤安全中心-安全中心</title><link rel="shortcut icon" href="/favicon.ico"><link href="/resources/css/index-76b9001b20-1.0.0.css" rel="stylesheet"></head><body><div id="app"></div><script src="./resources/js/configs.js"></script><script src="./resources/js/base.dll.js"></script><script src="/resources/js/index-bdcb04cb17-1.0.0.js"></script></body><script src="./resources/js/RSA.min.js"></script><script src="https://ssl.captcha.qq.com/TCaptcha.js"></script></html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
<!DOCTYPE html><html class="borderbox"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="renderer" content="webkit"><meta http-equiv="Expires" content="0"><meta http-equiv="pragram" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache"><meta name="description" content="福禄通行证"><meta name="keywords" content="福禄通行证"><title>福禄通行证-登录</title><link rel="shortcut icon" href="/favicon.ico"><link href="/resources/css/login-0d75dae610-1.0.0.css" rel="stylesheet"></head><body><div id="app"></div><script src="./resources/js/configs.js"></script><script src="./resources/js/base.dll.js"></script><script src="/resources/js/login-43ba7b1be5-1.0.0.js"></script></body><script src="./resources/js/RSA.min.js"></script><script src="https://ssl.captcha.qq.com/TCaptcha.js"></script></html> | ||
<!DOCTYPE html><html class="borderbox"><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="renderer" content="webkit"><meta http-equiv="Expires" content="0"><meta http-equiv="pragram" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache"><meta name="description" content="葫芦藤安全中心"><meta name="keywords" content="葫芦藤安全中心"><title>葫芦藤安全中心-登录</title><link rel="shortcut icon" href="/favicon.ico"><link href="/resources/css/login-826276cbf9-1.0.0.css" rel="stylesheet"></head><body><div id="app"></div><script src="./resources/js/configs.js"></script><script src="./resources/js/base.dll.js"></script><script src="/resources/js/login-bdcb04cb17-1.0.0.js"></script></body><script src="./resources/js/RSA.min.js"></script><script src="https://ssl.captcha.qq.com/TCaptcha.js"></script></html> |
Oops, something went wrong.