如何为 Identity Server 4 生成和添加签名密钥?

Posted

技术标签:

【中文标题】如何为 Identity Server 4 生成和添加签名密钥?【英文标题】:How To Generate and Add a Signing Key for Identity Server 4? 【发布时间】:2020-07-01 11:07:24 【问题描述】:

我在 CentOS 上托管我的 ASP.NET Core Web 应用程序。我需要为 Identity Server 设置生产签名密钥。此密钥用于 JWT 令牌签名和验证。

文件:tempkey.rsa


  "KeyId": "vbWO1QORQrwci26Cd7q59A",
  "Parameters": 
    "D": "IqOOHtuw10jHnCnrZbzh3TwA40q7KWuby22wl/ooRXn//XJktc8Hwe0JvxD8tvHtk4wfhzkUwiH+zY/cub+kI3oklD9diiWOjFIJcu+k9U9ocXg0ipvrk87rMM3x/u4im9HTYbkNU9Ru6pBdvb8ChAVWR5qOoSVDiFL1Yr8K+sSLix6nm6p0ax2CSf1sJEtNHDRrgI6mSOei97CpiuXpFX/JkwimqvbskcdQY91cgQ9poTWyuolFtFnOx0wSNEG4x1UWVsw85st5JHcU7pN0v1hhQZRcNYBfuZ7uHTFlhbkBip1D191pytSid8C4XTNiLbVPaY1pAqJhDLy6e7bi5Q==",
    "DP": "BVqSzlGs02ZFN9/xPug8VDZCxsReFmtd2xwhO8J7/JzGxxbbe9oq78q2blxDH6nY/I2M2DsKbm2BK2xE9ZHTkSuFHYw39OFHH3UZJNw8d3LMq8d2yZlzBTN21uKzVOwYd0zIchfvTIM3laOxW9j7sObOj8Nd/Pawkm2reFsmIzU=",
    "DQ": "BvpYLvxVPw7qrCtr6unhawV8ox4obq8WZEK/nu6hqBYxydW+zUJWv0fSYgygP9PYykGuTI+nYxCvm9rqw27uLoGsiEFT23Smzz5kDm0h+OzjJc5Wc+YL9wAI+O/xJ/Bi7uyKu+0eTMvG2Y5WpfYhJv2JZIWQUODHZ9SLDe8X3e8=",
    "Exponent": "AQAB",
    "InverseQ": "MKg8Pba2dyIsL3pumcR9e24fOZ8NIizJkTsDZoLkU2ccB6fFKfUioglHHL8ZEPKWT3ByJphJZv9JZIxgtCSLhFC1XcNLsWejPvEb6IMX9L1FIM7Ibo05L3tdZGTFsXwU9/3j2gk/ZFPKrnJXV9+6TToEAmxH7HIIPJONsfDBGho=",
    "Modulus": "nVpQtZgMHnpz9ZfnJs/sTkA8vqPldPe8IL9JQttcrE3RZKLKd+mrcleLqzrRtBCePHfLZMgoX19ShZeq2t4Ea6Sm+5SkV0l0862OD+ILnzFFqaqvQlra7UnRL2FXwxpp09LqLxoDq8fDXfHGOdMumP2TB6mozFgGWGBY9zlc9ctrDoSvfjsagcsLlp2LhCPAg4yCzyV/+4ADnls7NNnAc2Ba1MGFT5OJpfDggL+FXTMlHwTW8LJ9GsT4FAi5Z7dygLOnWc7zpl+Y9sSUtSNOAQlU+oX9VJQD6ZFbosM8nSHcjvCivpxAzOKn+5I6EQXis+pwne9VVjT27iv/NubG5Q==",
    "P": "z53dmREjm+MCchaWsvhPcWVWf7gGezix6KuGzMHa5vhVafrvv2rCy9aHSDWLpxPKb999/2Bw7ExI2b4DTuNkIJTLv/mQEl1PyhtbfLmclPHHbzTM9gnJ3nHrJhpj60/jbinFDkvzV++nqnTKToSgP2TNy5POXWn3FKNHgIxYNwM=",
    "Q": "wgXGJTOdv4B1owmtDmxucssRjWQzW0qEOCr/bBjT32ZofRI1HLBjOwnY4qzxmpD00voWLuphZSBUxtF47IZrrr33vNy2jedD3xy00fgBhuG0exxgQagCSTR0+QoccY8jOWYq2B+FsV9umpOEpgtqq67Moe/MkMp8Gg+8fqiLkfc="
  

现在,我需要为 ASP.NET Core 应用程序生成一个生产密钥。我正在将 Kestrel 与 nginx 一起使用。如何生成 key.rsa 文件并将其用于生产?

我也检查了其他问题。他们正在使用他们的 Windows 证书存储来读取证书。我需要一个使用 key.rsa 在 centos 上工作的解决方案。

到目前为止的代码::

    // Code skipped for brevity....

    #region Add ASP.NET Core Identity Server
        // Using ASP.NET Core Identity Server
        services.AddIdentityServer()
            .AddConfigurationStore<mysqlConfigurationDbContext>()
            .AddOperationalStore<MySQLPersistedGrantDbContext>()
            .AddAspNetIdentity<Identity.BOL.IdentityUser>()                
            .AddDeveloperSigningCredential();
        #endregion

        // Use Authentication
        services.AddAuthentication();                
    

【问题讨论】:

【参考方案1】:

我不清楚您是在问如何生成密钥,还是在生成密钥后如何使用它。我猜是第二个问题,因为您已经获得了您生成的密钥的示例。

您需要摆脱.AddIdentityServer 上的.UseDeveloperSigningCredential() 并使用其他一些构建器扩展便利方法:

https://identityserver4.readthedocs.io/en/latest/topics/startup.html#refstartupkeymaterial

或者,如果您需要更多自定义功能,请使用以下接口: https://identityserver4.readthedocs.io/en/latest/topics/crypto.html

但本质上,这些构建器扩展可能就是您所需要的。保持相同版本的代码,只是在 dev 和 live 上使用不同的密钥材料。

这是使用扩展方法的 x509 重载的示例,但您可以使用对您的关键材料有意义的任何方法:

    var x509 = new X509Certificate2(
         File.ReadAllBytes(somefilename),somepassword);

    services.AddIdentityServer(options =>
        
            the options I care about
        )
        .AddSigningCredential(x509)
        .AddValidationKey(x509);

【讨论】:

我都想要。我也想生成和使用。我找到了一个解决方案......只是想要。暂时查看其他解决方案。请展示你是如何做到的。 好吧,我们只使用 openssl 命令行来生成密钥。类似***.com/questions/5244129/… 我的答案中的代码 sn-p 只是从 PFX 文件创建 x509 证书。 PFX 文件是使用 openssl 创建的。考虑到 PFX 最初是由 PEM 材料创建的,这可能看起来有点漫长,但这是有原因的 :) 该服务也托管在 Centos 上,因此不会靠近Windows 证书存储。 正是我想要的...我正在使用完全相同的方法。您是使用单个密钥进行签名和验证还是使用两个不同的密钥?我用的是 100 年寿命的 @Ariel 您是否能够开发一个流程来自动生成新证书和自动密钥翻转?你愿意分享这个过程吗?

以上是关于如何为 Identity Server 4 生成和添加签名密钥?的主要内容,如果未能解决你的问题,请参考以下文章

如何为包含所有存储行的现有 SQL Server 表生成 INSERT 脚本?

在 SQL Server 中,如何为给定表生成 CREATE TABLE 语句?

从 python 使用 TSQL(SQL Server 上的 mssql)时,如何为 SQLAlchemy 自动生成 ORM 代码?

EF 5 + SQL Server CE 4:如何为数据库文件指定自定义位置?

如何为动态字段Angular 4创建表单生成器?

如何为每个班级和小组生成单独的小提琴图