胖哥和几个群友写了个好用的OAuth2授权服务器

举报
码农小胖哥 发表于 2022/05/14 01:00:23 2022/05/14
【摘要】 停更这些天,业余时间和粉丝群的几个大佬合作写了一个基于Spring Authorization Server的OAuth2授权服务器的管理控制台项目Id Server,我觉得这个项目能够大大降低OAuth2授权服务器使用难度。可以让你很方便地去管理OAuth2客户端信息,甚至可以一键生成OAuth2配置文件。接下来简单介绍一下...

3183e2b84afa5cb94cb8a4d341544cb7.gif

停更这些天,业余时间和粉丝群的几个大佬合作写了一个基于Spring Authorization ServerOAuth2授权服务器的管理控制台项目Id Server,我觉得这个项目能够大大降低OAuth2授权服务器使用难度。可以让你很方便地去管理OAuth2客户端信息,甚至可以一键生成OAuth2配置文件。接下来简单介绍一下Id Server这个项目,记得Star一下。

项目地址:https://github.com/NotFound403/id-server 

主要功能

  • 创建OAuth2客户端,并对OAuth2客户端进行管理。

  • 提供OAuth2授权服务。

  • 支持四种客户端认证方式:

    • CLIENT_SECRET_BASIC

    • CLIENT_SECRET_POST

    • CLIENT_SECRET_JWT

    • PRIVATE_KEY_JWT

  • 支持三种OAuth2授权方式:

    • AUTHORIZATION_CODE

    • CLIENT_CREDENTIALS

    • REFRESH_TOKEN

  • OIDC 1.0的支持(完善中)。

  • 一键生成配置yaml文件(正在开发中)。

  • 提供UI控制台,降低上手成本。

  • 可动态调整管理员的用户角色,对授权服务器进行按钮功能级别的权限控制。

主要技术

  • Spring Boot

  • Spring Security

  • Spring Authorization Server

  • Spring Data JPA

  • layui

  • thymeleaf

  • 数据库

    • H2

    • Mysql

截图

说这么多,不如放一些图更直观。

068bac9464a910e81c5ef17a1c896421.png66a4910d6a8b15a6a1168ebbb40c8e18.pnga804915995a0c545dee019868cf53e35.png78552c4f035b49b5718213740e3fe7a7.png6dbe994c44a374c6cf827ca898e5ca69.png14802f571ae2ae3c8e660562cb9a9ec4.pngef9016bf3b5703a9b0d74417a708a8dc.png

简单用法

  • 拉取主分支最新代码到本地。

  • 通过IdServerApplication来启动授权服务器。管理控制台本地登录路径为http://localhost:9000/system/login,最高权限用户为root,密码为idserver

  • 你可以通过root用户做这些事情:

    • 创建角色(角色管理)并为角色绑定权限。

    • 创建控制台管理用户(用户管理),并赋予他们角色。

退出功能还未完善,需要通过关闭浏览器来清除session。

OAuth2 测试方法

  • 启动Id Server,默认情况下在客户端列表提供了一个内置的OAuth2客户端。

  • 样例客户端在samples文件夹下,直接启动,浏览器配置文件下的http://127.0.0.1:8082/foo/bar,进入登录页,输入用户名user和密码user即可。

  • 你也可以在Id Server中创建一个客户端并模仿DEMO中的配置,主要修改client-id,client-secret,client-authentication-method,scope,其它选项除非你比较了解OAuth2,否则先不要动,也可以通过issue咨询。

redirect-uri必须在授权服务器Id Server注册客户端时声明。

如何替换内置用户user

首先要正确区分管理用户和普通用户这两个概念。

管理用户

root及其创建的用户为UI控制台的管理用户,超级管理员root是目前提供了一个默认用户,具有Id Server的最高权限。如果你需要自定义,可实现RootUserDetailsService接口并注入Spring IoC

普通用户

普通用户就是OAuth2中的资源拥有者,主要对OAuth2客户端的授权请求进行授权。默认提供了一个user用来演示,开发者可以实现OAuth2UserDetailsService接口并注入Spring IoC来自定义用户的来源。

多环境

目前Id Server提供H2Mysql两种数据库环境,分别对应application-h2.ymlapplication-mysql.yml两个配置文件。

  • H2,默认数据库,在H2环境下,数据库DDL脚本和DML脚本会自动执行,无需开发者手动执行,该环境主要用来测试、研究、学习。

  • Mysql,生产推荐,首次启动时开发者手动执行初始化DML脚本

目前两种环境的效果是一致的,切换时务必在pom.xml中更换对应的数据库驱动程序依赖。

愿景

这个项目希望能够帮助大家学习和使用OAuth2,目前项目主线功能已经完成,配置生成器和OIDC相关的功能正在跟进。希望大家多多支持,star一下。通过issues多提BUG,多提需求。

55139b8887952c5b7dabf86f3dbe77c9.png

文章来源: felord.blog.csdn.net,作者:码农小胖哥,版权归原作者所有,如需转载,请联系作者。

原文链接:felord.blog.csdn.net/article/details/124743488

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。