目录

一、微服务概述

1.1 微服务由来

1.2 微服务优势

1.3 微服务本质

1.4 微服务的认证与授权实现思路

1.5 权限管理数据模型(举例)

二、JWT概述

2.1 Sesssion认证与Token认证的区别

2.2 JWT的结构

三、微服务权限认证模块(以后补充)


一、微服务概述

1.1 微服务由来

微服务最早由 Martin Fowler 与 James Lewis 于 2014 年共同提出,微服务架构风格是一种 使用一套小服务来开发单个应用的方式途径,每个服务运行在自己的进程中,并使用轻量级机制通信,通常是 HTTP API,这些服务基于业务能力构建,并能够通过自动化部署机制独立部署,这些服务使用不同的编程语言实现,以及不同数据存储技术,并保持最低限度集中式管理

1.2 微服务优势

(1)微服务每个模块就相当于一个单独的项目,代码量明显减少,遇到问题也相对来说比较好解决。

(2)微服务每个模块都可以使用不同的存储方式(比如有的用 redis,有的用 mysql 等),数据库也是单个模块对应自己的数据库。

(3)微服务每个模块都可以使用不同的开发技术开发模式更灵活。

1.3 微服务本质

(1)微服务,关键其实不仅仅是微服务本身,而是系统要提供一套基础的架构,这种架构使得微服务可以独立的部署、运行、升级,不仅如此,这个系统架构还让微服务与微服务之间在结构上“松耦合”,而在功能上则表现为一个统一的整体。这种所谓的“统一的整 体”表现出来的是统一风格的界面统一的权限管理统一的安全策略统一的上线过程统一的日志和审计方法,统一的调度方式统一的访问入口等等。

(2)微服务的目的是有效的拆分应用,实现敏捷开发和部署。

1.4 微服务的认证与授权实现思路

(1)如果是基于 Session,那么 Spring-security 会对 cookie 里的 sessionid 进行解析,找 到服务器存储的 session 信息,然后判断当前用户是否符合请求的要求。

(2)如果是 token,则是解析token,然后将当前请求加入到 Spring-security 管理的权限 信息中去

如果系统的模块众多,每个模块都需要进行授权认证,所以我们选择基于 token 的形式 进行授权与认证。

用户根据用户名、密码认证成功,然后获取当前用户角色的一系列权限值,并以用户名为 key,权限列表为 value 的形式存入 redis 缓存中,根据用户名相关信息生成 token 返回,浏览器将 token 记录到 cookie 中,每次调用 api 接口都默认将 token 携带到 header 请求头中,Spring-security 解析 header 头获取 token 信息,解析 token 获取当前用户名,根据用户名就可以从 redis 中获取权限列表,这样 Spring-security 就能够判断当前请求是否有权限访问。

1.5 权限管理数据模型(举例)

二、JWT概述

 Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC 7519).该token被设计为紧凑且安全的,特别适用于分布式站点单点登录(SSO)场景。JWT的声明一般被用来在身份提供者服务提供者间传递被认证用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。

2.1 Sesssion认证与Token认证的区别

1.Session

http协议本身是一种无状态的协议,而这就意味着如果用户向我们的应用提供了用户名和密码来进行用户认证,那么下一次请求时,用户还要再一次进行用户认证才行,因为根据http协议,我们并不能知道是哪个用户发出的请求,所以为了让我们的应用能识别是哪个用户发出的请求,我们只能在服务器存储一份用户登录的信息,这份登录信息会在响应时传递给浏览器,告诉其保存为cookie,以便下次请求时发送给我们的应用(sessionID),这样我们的应用就能识别请求来自哪个用户了,这就是传统的基于session认证。

但是这种基于session的认证使应用本身很难得到扩展,随着不同客户端用户的增加,独立的服务器已无法承载更多的用户,而这时候基于session认证应用的问题就会暴露出来.

2.Token

基于token的鉴权机制类似于http协议也是无状态的,它不需要在服务端去保留用户的认证信息或者会话信息。这就意味着基于token认证机制的应用不需要去考虑用户在哪一台服务器登录了,这就为应用的扩展提供了便利。

流程上是这样的:

  • 用户使用用户名密码来请求服务器
  • 服务器进行验证用户的信息
  • 服务器通过验证发送给用户一个token
  • 客户端存储token,并在每次请求时附送上这个token值
  • 服务端验证token值,并返回数据

这个token必须要在每次请求时传递给服务端,它应该保存在请求头

2.2 JWT的结构

总共有以下三个部分:JWT 头有效载荷签名

1. JWT 头部分是一个描述 JWT 元数据的 JSON 对象

{
"alg": "HS256",
"typ": "JWT"
}

2.有效载荷部分是 JWT 的主体内容部分,也是一个 JSON 对象,包含需要传递的数据。 JWT 指定七个默认字段供选择。

iss:发行人

exp:到期时间

sub:主题

aud:用户

nbf:在此之前不可用

iat:发布时间

jti:JWT ID 用于标识该 JWT

除以上默认字段外,我们还可以自定义私有字段

{
"sub": "1234567890",
"name": "Helen",
"admin": true
}

注:默认情况下 JWT 是未加密的,任何人都可以解读其内容,因此不要构建隐私信息字段,存放保密信息,以防止信息泄露。

3.签名哈希是对上面两部分数据签名,通过指定的算法生成哈希,以确保数据不会被篡改

在计算出签名哈希后,JWT 头有效载荷签名哈希的三个部分组合成一个字符串,每个部分用" "分隔,就构成整个 JWT 对象

三、微服务权限认证模块(以后补充)

SpringSecurity-基于微服务的认证与权限访问相关推荐

  1. 如何删除网关的session_微服务安全认证架构是如何演进而来的?坐好小板凳一起来听一听...

    之前有同事问为何要用基于JWT令牌的认证架构,然后近期又有童鞋在后台留言问微服务安全认证架构的实践,因此我决定花两篇推文来解答一下.为了答好这个话题,我们先来看看微服务的安全认证架构是如何演进而来的, ...

  2. 【Spring Cloud Alibaba 实战 | 总结篇】Spring Cloud Gateway + Spring Security OAuth2 + JWT 实现微服务统一认证授权和鉴权

    一. 前言 hi,大家好~ 好久没更文了,期间主要致力于项目的功能升级和问题修复中,经过一年时间这里只贴出关键部分代码的打磨,[有来]终于迎来v2.0版本,相较于v1.x版本主要完善了OAuth2认证 ...

  3. 基于微服务下的持续交付环境

    背景 随着互联网行业的兴起,敏捷开发.Devops被越来越多的公司提及或实施,力求有效地降低交付过程所耗费的成本并提高交付的效率. 持续交付通过建立自动化的构建.测试.部署机制,实现业务快速上线的过程 ...

  4. 基于微服务架构的餐饮系统的设计与实现计算机毕业设计源码86393

    摘    要 近年来,我国经济和社会发展迅速,人们物质生活水平日渐提高,餐饮行业更是发展迅速,人们对于餐饮行业的认识和要求也越来越高.传统形式的餐饮行业都是以人为本,管理起来需要很多人力.物力.财力, ...

  5. re.containerbase.startinternal 子容器启动失败_微服务架构:基于微服务和Docker容器技术的PaaS云平台架构设计(微服务架构实施原理)...

    走过路过不要错过 点击蓝字关注我们 基于微服务架构和Docker容器技术的PaaS云平台建设目标是给我们的开发人员提供一套服务快速开发.部署.运维管理.持续开发持续集成的流程.平台提供基础设施.中间件 ...

  6. 基于微服务和Docker的PaaS云平台架构设计

    基于微服务架构和Docker容器技术的PaaS云平台建设目标是给我们的开发人员提供一套服务快速开发.部署.运维管理.持续开发持续集成的流程.平台提供基础设施.中间件.数据服务.云服务器等资源,开发人员 ...

  7. 基于微服务和Docker容器技术的PaaS云平台架构设计

    本文讲的是基于微服务和Docker容器技术的PaaS云平台架构设计[编者的话]在系统架构上,PaaS云平台主要分为微服务架构.Docker容器技术.DveOps三部分,这篇文章重点介绍微服务架构的实施 ...

  8. SWIFT PLM 介绍|基于微服务架构的Swift PLM云平台

    基于微服务架构的Swift PLM云平台 1.       Swift PLM 云平台基于微服务架构 杰信软件公司致力于一系列基于PLM系统的实施及二次开发的解决方案,并在近期取得巨大进展,自主研发了 ...

  9. 业务中台 全渠道一盘货 基于微服务的订单管理系统OMS 开源

    一.项目背景 将中台改造成通用的系统,实现快速部署,并帮助企业后续自主进行开发迭代,来帮助企业实现数字化转型. 提供的中台系统包括:通用业务中台.强大的技术中台.后续开发方案的设计,技术及管理人员的培 ...

最新文章

  1. controlfile
  2. 【Android View绘制之旅】主脉络
  3. 电脑装windows和ubuntu,如何卸载ubuntu系统
  4. 字节跳动简历冷却期_干货 | 字节跳动HR是如何挑选简历的?
  5. 夜神模拟器模拟安卓测试_使用模拟进行测试
  6. 【2016年第1期】从政策驱动到技术践行:大数据开辟可持续发展研究新途径
  7. 三星核S5PV210AH-A0 SAMSUNG
  8. 2018/12/13
  9. 痛恨3721的朋友们,装个avast! Antivirus吧
  10. RxJava -- 从 create 开始 (一)
  11. 天正多条线段长度lisp下载_如何快速计算cad中多条多段线的总长
  12. 朱朱的2020年(上)
  13. IDEA导入Eclipse项目--ecli
  14. 微信公众号如何插入html,教你如何在微信公众号优雅的展示代码
  15. 网络学习之网络通信设备辨析
  16. 微信小程序 手写签名_微信小程序实现电子签名功能
  17. URL中的20%、22%、26%、7B%、%7D、28%、29%解析成真实的字符
  18. 解决电脑开机-EFI PXE 0 for IPv4(XX-XX-XX-XX-XX-XX) boot failed.问题
  19. 利用java代码一键生成数据库文档
  20. WRF-Chem 编译fire_emis报错

热门文章

  1. Win10 虚拟桌面的使用
  2. java开发程序员培训班,成功跳槽阿里!
  3. Web服务器集群——Apache网页与安全优化
  4. Oracle11g 调整表空间大小 Resize
  5. CSDN外链解决方法 (2022-07-28测试可用)
  6. LINUX内核内存屏障
  7. 使用python批量修改图片名称
  8. map和filter方法对于稀缺数组的处理
  9. 支持多线程编程的Web Workers
  10. Android APK 反编译浅入浅出:apktool 、dex2jar 、jd-gui