网站首页 > java教程 正文
技术框架
springboot+shiro+oltu+thymeleaf+vue.js
项目地址:秋风 (qiufeng9862) - Gitee.com
单服务版本: OAuth2-SSO
增加微服务版本,具体地址查看mfish-cloud
项目介绍
Maven项目, 字符编码: UTF-8;
基于springboot框架整合shiro安全验证框架,基于oltu实现oauth2单点登录认证
前端采用thymeleaf+vue.js实现
项目由core,web_oauth2_server,app_oauth2_server三部分组成
core为核心验证逻辑
web_oauth2_server提供web前端通过跳转方式登录
app_oauth2_server提供手机app登录接口
主要技术版本
JDK(1.8)
springboot(2.2.4.RELEASE)
shiro(1.4.2)
oltu(1.0.2)
功能列表
当前版本 V1.0.9
1.支持扫码登录、账号密码、短信验证码登录、相同session免登录(后面版本扩充多种登录方式认证)
2.支持authorization_code,password,refresh_token三种获取token方式
3.支持redis session缓存
4.支持热用户,热客户端暂存 (账号信息,客户端信息访问后暂存redis中,下次请求直接访问redis不再请求数据库,长期不使用会被清理)
5.支持账号登录互斥功能(不同电脑或手机登录时踢出之前登录的账号)
6.支持登录日志记录
后期计划
v1.1.0
1.增加流控
v2.0.0
1.增加权限管理
安装教程
- 使用MAVEN命令将代码导入到idea或者其他IDE中
- 安装lombok插件(如果已安装忽略此步骤)
- 执行目录中 SQL建表语句 创建登录相关表
- 安装本机redis,并启动
- 运行
使用说明
/swagger-ui.html查看接口文档
- 获取code
访问/oauth2/authorize?response_type=code&client_id={client_id}&redirect_uri={redirect_uri}&state={state} - 输入账号admin 密码!QAZ2wsx 提交
- 系统回调{redirect_uri}?code={code}&state={state}
- 示例:
访问 /oauth2/authorize?response_type=code&client_id=system&redirect_uri=http://baidu.com
返回 baidu.com?code=**************** - 获取token
根据回调返回code,post方式调用/oauth2/accessToken接口返回token信息
注意:Content-Type=application/x-www-form-urlencoded - 示例参数:
header配置Content-Type=application/x-www-form-urlencoded
[{"key":"client_id","value":"system","description":""},{"key":"client_secret","value":"system","description":""},{"key":"grant_type","value":"authorization_code","description":""},{"key":"code","value":"77c9c36b1d9ef13f366d20f47789c80b","description":""},{"key":"redirect_uri","value":"http://baidu.com","description":""}] - 获取用户信息
get方式请求/user/info?access_token={access_token}获取用户信息 - 示例:
/user/info?access_token=****************
或者
也可将token信息放入header中 设置Authorization=Bearer{access_token} get请求http://localhost:19888/user/info - 用户登出
访问/user/revoke 登出账号
- 上一篇: golang 单点登录系统(go-sso)
- 下一篇: JWT实现单点登录问题
猜你喜欢
- 2025-04-26 DuckDuckGo应用和扩展全面禁止谷歌的单点登录弹窗
- 2025-04-26 单点登录的终级解决方案-xxlSso
- 2025-04-26 单点登录(SSO)原理大揭秘:大龄程序员的硬核解析,看完秒懂!
- 2025-04-26 到底什么是单点登录(SSO)?
- 2025-04-26 带你全面了解 OAuth2.0
- 2025-04-26 单点登录和统一认证有区别吗
- 2025-04-26 单点登录解决方案 CAS(Central Authentication Service)详解
- 2025-04-26 JWT与OAuth2结合打造高效的单点登录系统
- 2025-04-26 统一认证及单点登录解决方案
- 2025-04-26 【免费开源】JeecgBoot单点登录源码全部开源了
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)