基于非对称密钥的http api认证

asymmetric_jwt_auth的Python项目详细描述


https://img.shields.io/pypi/v/asymmetric_jwt_auth.svghttps://travis-ci.org/crgwbr/asymmetric-jwt-auth.svg

什么?

这是一个库,用于处理 服务器到服务器api请求。它使用rsa public实现了这一点/ 私钥对。

为什么?

使用用户名和密码的标准模式对于 用户到服务器的请求,但缺少服务器到服务器的请求 应用。在这些情况下,因为密码不需要 让用户难忘的是,我们可以使用更安全的东西:不对称 密钥加密。这样做的好处是密码永远不会 实际发送到服务器。

怎么做?

客户端计算机生成公钥/私钥对。这个 然后为服务器计算机提供公钥,它可以存储 以任何它喜欢的方式。当这个库与django一起使用时, 提供用于存储与内置用户关联的公钥的模型 物体。当发出请求时,客户机创建一个jwt,包括 有人声称并用私钥签名。收到后, 服务器验证使用公钥的声明以确保颁发者 是他们声称的合法身份。

索赔(由客户发出)包括以下组件:的用户名 正在尝试身份验证的用户,当前的unix时间戳, 以及随机生成的nonce。例如:

{
    "username": "guido",
    "time": 1439216312,
    "nonce": "1"
}

时间戳必须在服务器时间和 nonce在给定的时间戳和用户内必须是唯一的。在其他方面 如果一个用户的多个请求是在同一个 其次,现在必须改变。由于这两个因素 可多次使用,从而防止重播攻击。

要发出经过身份验证的请求,客户端必须生成jwt 遵循上述格式并将其作为http授权包括在内 标题格式如下:

Authorization: JWT <my_token>

important note:声明是not加密的,仅签名的。 另外,签名只能防止声明被篡改 使用或重复使用。请求的其他部分仍然容易受到 捣乱。因此,这不能替代在 传输层。

完整文档https://asymmetric-jwt-auth.readthedocs.io

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
用于切换状态结果的枚举的java输入   检测*NIX上打开的端口时出现java问题   java捕获和保存屏幕截图   java SLF4JLogback:基于日志级别的多模式   Java从字符串中删除动态子字符串   在spring引导中contextLoads测试时运行java Liquibase   基于规则集的任意嵌套POJO的java任意就地转换   java如何做,边做边循环这段代码?   java是什么导致jmh测量中的错误?   java Spring RabbitTemplate执行方法可见性   java jms创建连接http超时weblogic   java如何在JMapViewer中的两点之间放置像箭头一样的图像   在我的形状计算器Java程序中使用带有Switch/Case语句的循环   字符串如何在Java中比较字符和数字