Skip to content

Commit

Permalink
1.1版本提交
Browse files Browse the repository at this point in the history
  • Loading branch information
longxianghui committed Nov 9, 2020
1 parent 0ecd9d8 commit 55d1225
Show file tree
Hide file tree
Showing 71 changed files with 43,387 additions and 184 deletions.
192 changes: 178 additions & 14 deletions README.md
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代码到本地。根目录结构如下:

![20201103153907](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201103153907.png)

其中,backend存放的是后端代码,frontend存放的是前端代码。

进入backend目录,使用Visual Studio打开解决方案。目录结构如下:

![20201103154250](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201103154250.png)

#### 2.生成数据库

首先在Fulu.Passport.Web中找到appsettings.Development.json文件。编辑数据库连接字符串:

![20201103155350](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201103155350.png)


打开程序包管理器,切换默认项目为:Fulu.Passport.Web, 如下图所示:


![20201106111334](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201106111334.png)


然后在程序包管理器中执行如下命令:

```
Add-Migration Init
```
最后执行完成后,再执行如下命令:
```
update-database
```
执行完以上操作后,如没有报错,则会创建数据库,并会在Client表中创建一条测试数据,如下图所示:

![20201103160408](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201103160408.png)



#### 3.按F5启动后端服务

注:由于项目中依赖redis来处理缓存,所以正式启动之前,需要将appsettings.Development.json文件里的redis配置改为你自己的。

#### 4.启动前端

切换目录到frontend,在命令行中执行如下命令:

```
npm install
```
执行完毕后,执行如下命令:

### 2.运行命令行
```
npm run demo
```

执行结果如下图所示:

![20201103161300](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201103161300.png)

然后通过http://localhost:8080进行访问。界面如下所示:

![20201103174200](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201103174200.png)

至此,前后端服务已启动完毕,一个开箱即用的认证授权服务就完成了。

#### 5.新客户端如何快速接入认证服务?

认证授权服务存在的意义就是提供统一的认证授权入口,有了这个服务后,每个新的客户端应用无需单独开发认证授权模块。下面就来一起看下如何快速将新应用接入到认证授权服务。(*此处以 ASP.NET Core作为示例,其他语言大同小异*)。

示例代码在sample文件夹中,如下图所示:

![20201104165955](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201104165955.png)

在正式接入之前,必须先申请应用。(此版本未提供应用管理服务)通过在数据库中添加示例信息,如下图所示:

![20201104192124](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201104192124.png)

示例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项目引用,如下图所示:

![20201104170401](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/20201104170401.png)

然后在Configure方法中,添加如下代码:


```
app.UseRouting();
app.UseJwtAuthorize();
app.UseAuthorization();
```

其中,UseJwtAuthorize是自定义的中间件,为了实现OAuth2.0的授权码的逻辑。
限于篇幅,具体代码不在此列出。可在代码仓库中查看。

到此为止,这个新应用就成功的接入到认证服务了。

当未登录的时候,访问此应用的页面会自动跳转到认证服务的login界面。登录之后,会重定向回登录之前的页面。如下图所示:

![aa](https://fulu-item11-zjk.oss-cn-zhangjiakou.aliyuncs.com/images/aa.gif)



## 下一版功能规划

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静态资源至服务器
18 changes: 15 additions & 3 deletions frontend/ant-icon.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
export {
default as LoadingOutline
} from '@ant-design/icons/lib/outline/LoadingOutline';
export {
default as QuestionCircleFill
} from '@ant-design/icons/lib/fill/QuestionCircleFill';
export {
default as EyeFill
} from '@ant-design/icons/lib/fill/EyeFill';
export {
default as EyeInvisibleFill
} from '@ant-design/icons/lib/fill/EyeInvisibleFill';
export {
default as QuestionCircleFill
} from '@ant-design/icons/lib/fill/QuestionCircleFill';
export {
default as InfoCircleFill
} from '@ant-design/icons/lib/fill/InfoCircleFill';
Expand All @@ -31,3 +31,15 @@ export {
export {
default as SearchOutline
} from '@ant-design/icons/lib/outline/SearchOutline';
export {
default as InfoCircleOutline
} from '@ant-design/icons/lib/outline/InfoCircleOutline';
export {
default as CheckCircleOutline
} from '@ant-design/icons/lib/outline/CheckCircleOutline';
export {
default as CloseCircleOutline
} from '@ant-design/icons/lib/outline/CloseCircleOutline';
export {
default as ExclamationCircleOutline
} from '@ant-design/icons/lib/outline/ExclamationCircleOutline';
2 changes: 1 addition & 1 deletion frontend/build/webpack-assets.json
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"]}}
1 change: 1 addition & 0 deletions frontend/dist/bindAccount.html
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>
2 changes: 1 addition & 1 deletion frontend/dist/error.html
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>
2 changes: 1 addition & 1 deletion frontend/dist/index.html
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>
2 changes: 1 addition & 1 deletion frontend/dist/login.html
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>
Loading

0 comments on commit 55d1225

Please sign in to comment.