点击关注公众号,Java干货及时送达

今天给大家推荐的这个开源项目超级棒,可能是史上功能最全的 Java 权限认证框架!

这个开源项目就是:sa-token 。

Sa-Token是什么?

sa-token是一个轻量级Java权限认证框架,主要解决:登录认证、权限认证、Session会话、单点登录、OAuth2.0 等一系列权限相关问题

框架针对踢人下线、自动续签、前后台分离、分布式会话……等常见业务进行N多适配,通过sa-token,你可以以一种极简的方式实现系统的权限认证部分

与其它权限认证框架相比,sa-token 具有以下优势:

  1. 简单 :可零配置启动框架,真正的开箱即用,低成本上手

  2. 强大 :目前已集成几十项权限相关特性,涵盖了大部分业务场景的解决方案

  3. 易用 :如丝般顺滑的API调用,大量高级特性统统只需一行代码即可实现

  4. 高扩展 :几乎所有组件都提供了扩展接口,90%以上的逻辑都可以按需重写

有了sa-token,你所有的权限认证问题,都不再是问题!

Sa-Token 能做什么?

  • 登录验证 —— 轻松登录鉴权,并提供五种细分场景值

  • 权限验证 —— 适配RBAC权限模型,不同角色不同授权

  • Session会话 —— 专业的数据缓存中心

  • 踢人下线 —— 将违规用户立刻清退下线

  • 持久层扩展 —— 可集成Redis、Memcached等专业缓存中间件,重启数据不丢失

  • 分布式会话 —— 提供jwt集成和共享数据中心两种分布式会话方案

  • 单点登录 —— 一处登录,处处通行

  • 模拟他人账号 —— 实时操作任意用户状态数据

  • 临时身份切换 —— 将会话身份临时切换为其它账号

  • 无Cookie模式 —— APP、小程序等前后台分离场景

  • 同端互斥登录 —— 像QQ一样手机电脑同时在线,但是两个手机上互斥登录

  • 多账号认证体系 —— 比如一个商城项目的user表和admin表分开鉴权

  • 花式token生成 —— 内置六种token风格,还可自定义token生成策略

  • 注解式鉴权 —— 优雅的将鉴权与业务代码分离

  • 路由拦截式鉴权 —— 根据路由拦截鉴权,可适配restful模式

  • 自动续签 —— 提供两种token过期策略,灵活搭配使用,还可自动续签

  • 会话治理 —— 提供方便灵活的会话查询接口

  • 组件自动注入 —— 零配置与Spring等框架集成

  • 更多功能正在集成中... —— 如有您有好想法或者建议,欢迎加群交流

代码示例

sa-token的API调用非常简单,有多简单呢?以登录验证为例,你只需要:

// 在登录时写入当前会话的账号id
StpUtil.setLoginId(10001);// 然后在任意需要校验登录处调用以下API
// 如果当前会话未登录,这句代码会抛出 `NotLoginException`异常
StpUtil.checkLogin();

至此,我们已经借助sa-token框架完成登录授权!

此时的你小脑袋可能飘满了问号,就这么简单?自定义Realm呢?全局过滤器呢?我不用写各种配置文件吗?

事实上在此我可以负责的告诉你,在sa-token中,登录授权就是如此的简单,不需要什么全局过滤器,不需要各种乱七八糟的配置!只需要这一行简单的API调用,即可完成会话的登录授权!

当你受够Shiro、Security等框架的三拜九叩之后,你就会明白,相对于这些传统老牌框架,sa-token的API设计是多么的清爽!

权限认证示例 (只有具有user:add权限的会话才可以进入请求)

@SaCheckPermission("user:add")
@RequestMapping("/user/insert")
public String insert(SysUser user) {
return "用户增加";
}

将某个账号踢下线 (待到对方再次访问系统时会抛出NotLoginException异常)

// 使账号id为10001的会话注销登录
StpUtil.logoutByLoginId(10001);

除了以上的示例,sa-token还可以一行代码完成以下功能:

StpUtil.setLoginId(10001);                // 标记当前会话登录的账号id
StpUtil.getLoginId();                     // 获取当前会话登录的账号id
StpUtil.isLogin();                        // 获取当前会话是否已经登录, 返回true或false
StpUtil.logout();                         // 当前会话注销登录
StpUtil.logoutByLoginId(10001);           // 让账号为10001的会话注销登录(踢人下线)
StpUtil.hasRole("super-admin");           // 查询当前账号是否含有指定角色标识, 返回true或false
StpUtil.hasPermission("user:add");        // 查询当前账号是否含有指定权限, 返回true或false
StpUtil.getSession();                     // 获取当前账号id的Session
StpUtil.getSessionByLoginId(10001);       // 获取账号id为10001的Session
StpUtil.getTokenValueByLoginId(10001);    // 获取账号id为10001的token令牌值
StpUtil.setLoginId(10001, "PC");          // 指定设备标识登录
StpUtil.logoutByLoginId(10001, "PC");     // 指定设备标识进行强制注销 (不同端不受影响)
StpUtil.switchTo(10044);                  // 将当前会话身份临时切换为其它账号

开源项目地址:

https://github.com/click33/sa-token

热门内容:
美团面试题:String s = new String("111")会创建几个对象?再见,HttpClient!再见,Okhttp!最近面试BAT,整理一份面试资料《Java面试BAT通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。获取方式:点“在看”,关注公众号并回复 666 领取,更多内容陆续奉上。

明天见(。・ω・。)ノ

这可能是史上功能最全的Java权限认证框架!相关推荐

  1. 这可能是史上功能最全的 Java 权限认证框架!

    点击关注公众号,回复"1024"获取2TB学习资源! 今天给大家推荐的这个开源项目超级棒,可能是史上功能最全的 Java 权限认证框架! Sa-Token 介绍 Sa-Token是 ...

  2. 再见Spring Security!推荐一款功能强大的权限认证框架,用起来够优雅!

    ‍ ‍在我们做SpringBoot项目的时候,认证授权是必不可少的功能!我们经常会选择Shiro.Spring Security这类权限认证框架来实现,但这些框架使用起来有点繁琐,而且功能也不够强大. ...

  3. 再见Spring Security、推荐一款功能强大的权限认证框架

    Sa-Token简介 Sa-Token是一款轻量级的Java权限认证框架,可以用来解决登录认证.权限认证.Session会话.单点登录.OAuth2.0.微服务网关鉴权等一系列权限相关问题. 框架集成 ...

  4. 史上最详细全中文 Cisco 3560交换机使用手册

    史上最详细全中文 Cisco 3560交换机使用手册 (末尾送交换机安全技术) 目 录 CISCO Catalyst 3560-E系列交换机的功能应用及安全解决方案 3 一.Cisco? Cataly ...

  5. 全网史上最详细全面的Linux下安装mysql客户端服务端

    全网史上最详细全面的Linux下安装mysql客户端服务端Linux下安装mysql 1.上传MySQL5.6的tar包 创建目录: mkdir /usr/local/src/mysql5.6 上传: ...

  6. 我宣布,这是我找到的史上AI最全论文体系!

    在碎片化阅读充斥眼球的时代,越来越少的人会去关注每篇论文背后的探索和思考. 搞AI,不少人都进入一个误区,那就是只钻研自己的代码是否精进,而没有注意提升自己的阅读能力.实际上,一个专业的学术研究员或者 ...

  7. 还在用Spring Security?推荐你一款使用简单、功能强大的权限认证框架

    欢迎关注方志朋的博客,回复"666"获面试宝典 来源:blog.csdn.net/qq_40058629/article/ details/116692302 我们先看一下官网介绍 ...

  8. 【登录及鉴权】-盘点那些主流的开源登录及权限认证框架 (上)

    登录和鉴权应该是一个完整的系统中几乎必不可少的部分,虽然现在已经有越来越多的框架帮我们简化了这部分工作量,大公司更是有自己专门的登录和权限控制系统,比如阿里的BUC和ACL,开发者仅需要通过简单的步骤 ...

  9. netbeans 添加gif图片_史上功能最强最全最好用的GIF动画制作手机app——GIF豆豆——手机ae...

    今天给大家介绍一款手机app,可以说满足了你对GIF制作的所有需求(另外表情in和视频豆豆这两款App也可以) GIF豆豆_其他软件类GIF豆豆软件下载_百度手机助手​shouji.baidu.com ...

最新文章

  1. 注释符、快捷键、变量及其命名规则
  2. 鸟哥的Linux私房菜(基础学习,服务器架设)
  3. 2014东师计算机应用基础离线作业,2014秋东师《计算机应用基础》离线作业及答案...
  4. Windows键盘如何映射为Mac使用
  5. python下载网易云音乐付费歌曲有哪些_学习python总结 - 下载网易云音乐单首歌曲...
  6. python将一维数组导入到excel表格,并使用Origin绘图
  7. 量子研究再获突破能否成功解决核潜艇通信难题?
  8. 深度优先搜索—走迷宫
  9. 在centOS中安装以及使用vim编辑器
  10. 抖音推出放映厅,可以免费看电影追剧
  11. 【新知实验室】——腾讯云音视频TRTC体验
  12. 错误 1 error MSB4062: 未能从程序集 C:\caffe\NugetPackages\OpenCV.2.4.10\buil
  13. erp系统有哪些功能模块?
  14. python nonlocal 的应用
  15. UCML Ajax++框架介绍
  16. H7-TOOL高速DAPLINK仿真器功能已发布,支持WinUSB和HID方式二合一,含常见问题FAQ(2020-12-07)
  17. 从头开始进行CUDA编程:线程间协作的常见技术
  18. CorelDRAW CORE压缩包X4教你快速入门制作立体五角星
  19. 实现断网收银_2019超市连锁店收银系统前5名
  20. Swoole使用场景及代码实现

热门文章

  1. 怎么用vc采集ni卡数据_智能水表读数怎么看?家用智能水表怎么安装?
  2. wireless(二维数组前缀和)
  3. oracle测试环境表空间清理
  4. 图片lightbox2
  5. [2014百度之星资格赛]
  6. 判断JS对象是否拥有某属性两种方式
  7. 一个非常简单的 ASP.NET MVC 示例:长轮询(又叫:反向 AJAX,英文名:Comet)实现...
  8. C#设置本地网络(DNS、网关、子网掩码、IP)
  9. 如何关闭事件跟踪程序
  10. 电子学会青少年编程等级考试Python案例08