扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
背景
从传统的单体应用转型Spring Cloud的朋友都在问我,Spring Cloud
下的微服务权限怎么管?怎么设计比较合理?从大层面讲叫服务权限,往小处拆分,分别为三块:用户认证
、用户权限
、服务校验
。
用户认证
传统的单体应用可能习惯了session的存在,而到了Spring cloud的微服务化后,session虽然可以采取分布式会话来解决,但终究不是上上策。开始有人推行Spring Cloud Security结合很好的OAuth3
,后面为了优化OAuth 2中Access Token
的存储问题,提高后端服务的可用性和扩展性,有了更好Token验证方式JWT
(JSON Web Token)。这里要强调一点的是,OAuth3
和JWT
这两个根本没有可比性,是两个完全不同的东西。OAuth3是一种授权框架
,而JWT
是一种认证协议
OAuth3认证框架OAuth3中包含四个角色:
OAuth3包含4种授权模式
其中,OAuth3的运行流程如下图,摘自RFC 6749:
+--------+ +---------------+ | |--(A)- Authorization Request ->| Resource | | | | Owner | | |<-(B)-- Authorization Grant ---| | | | +---------------+ | | | | +---------------+ | |--(C)-- Authorization Grant -->| Authorization | | Client | | Server | | |<-(D)----- Access Token -------| | | | +---------------+ | | | | +---------------+ | |--(E)----- Access Token ------>| Resource | | | | Server | | |<-(F)--- Protected Resource ---| | +--------+ +---------------+
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流