zoukankan      html  css  js  c++  java
  • JWT与Zuul

    非对称加密

    加密技术是对信息进行编码和解码的技术,编码是把原来可读信息(又称明文)译成代码形式(又称密文),其逆过程就是解码(解密),加密技术的要点是加密算法,加密算法可以分为三类:

    • 对称加密,如AES
      • 基本原理:将明文分成N个组,然后使用密钥对各个组进行加密,形成各自的密文,最后把所有的分组密文进行合并,形成最终的密文。
      • 优势:算法公开、计算量小、加密速度快、加密效率高
      • 缺陷:双方都使用同样密钥,安全性得不到保证
    • 非对称加密,如RSA
      • 基本原理:同时生成两把密钥:私钥和公钥,私钥隐秘保存,公钥可以下发给信任客户端
        • 私钥加密,持有私钥或公钥才可以解密
        • 公钥加密,持有私钥才可解密
      • 优点:安全,难以破解
      • 缺点:算法比较耗时
    • 不可逆加密,如MD5,SHA
      • 基本原理:加密过程中不需要使用密钥,输入明文后由系统直接经过加密算法处理成密文,这种加密后的数据是无法被解密的,无法根据密文推算出明文。

    RSA算法历史:

    1977年,三位数学家Rivest、Shamir 和 Adleman 设计了一种算法,可以实现非对称加密。这种算法用他们三个人的名字缩写:RSA

    Zuul的鉴权流程

    我们逐步演进系统架构设计。需要注意的是:secret是签名的关键,因此一定要保密,我们放到鉴权中心保存,其它任何服务中都不能获取secret。

    1.5.1.没有RSA加密时

    在微服务架构中,我们可以把服务的鉴权操作放到网关中,将未通过鉴权的请求直接拦截,如图:

    • 1、用户请求登录
    • 2、Zuul将请求转发到授权中心,请求授权
    • 3、授权中心校验完成,颁发JWT凭证
    • 4、客户端请求其它功能,携带JWT
    • 5、Zuul将jwt交给授权中心校验,通过后放行
    • 6、用户请求到达微服务
    • 7、微服务将jwt交给鉴权中心,鉴权同时解析用户信息
    • 8、鉴权中心返回用户数据给微服务
    • 9、微服务处理请求,返回响应

    发现什么问题了?

    每次鉴权都需要访问鉴权中心,系统间的网络请求频率过高,效率略差,鉴权中心的压力较大。

    .结合RSA的鉴权

    直接看图:

    • 我们首先利用RSA生成公钥和私钥。私钥保存在授权中心,公钥保存在Zuul和各个微服务
    • 用户请求登录
    • 授权中心校验,通过后用私钥对JWT进行签名加密
    • 返回jwt给用户
    • 用户携带JWT访问
    • Zuul直接通过公钥解密JWT,进行验证,验证通过则放行
    • 请求到达微服务,微服务直接用公钥解析JWT,获取用户信息,无需访问授权中心
    • 微信公众号
    •                           
  • 相关阅读:
    编译freeglut-3.0.0的Windows版静态库,及其使用示例
    关于网络安全与实名上网的通知
    【机器学习库】mlpack 2.1.1 Ubuntu14.0.4 踩坑记录
    【OpenCV】在Linux下用CMAKE编译安装OpenCV3.2.0
    【Python装饰者】在函数测试的作用
    【校验】TCP和UDP的校验和
    【C++设计模式】单件类与DCLP(Double Check Lock Pattern)的风险
    【爬虫】Python2 爬虫初学笔记
    【统计学习】SVM之超平面方程来源
    【滤波】标量Kalman滤波的过程分析和证明及C实现
  • 原文地址:https://www.cnblogs.com/niugang0920/p/12186597.html
Copyright © 2011-2022 走看看