使用公钥验证端点签名JWT

瑞恩d:

我想验证从微软的一些JWTs的签名。我使用的是春天开机,JJWT库和以下端点:https://login.microsoftonline.com/common/discovery/v2.0/keys

端点返回JSON公钥的数组。下面是从阵列的一个例子。

 {
            "kty": "RSA",
            "use": "sig",
            "kid": "9FXDpbfMFT2SvQuXh846YTwEIBw",
            "x5t": "9FXDpbfMFT2SvQuXh846YTwEIBw",
            "n": "kvt1VmR4nwkNM8jMU0wmj2gSS8NznbOt2pZI6Z7HQT_esF7W19GZR7Y72Xo1i5zXRDM9o3GeTIjBrnr3yy41Q_EaUQ7C-b-Hmg94Vy7EBZyBhi_mznz0dYWs2MIXwR86Nni9TmgTXvjgTPF2YGJoZt4TwcMFefW8rijCVyNrCBA0XspDouNJavvG0BEMXYigoThFjLRXS5U3h4BDfNZFZZS3dyliNOXfgRn2k7oITz8h_ueiPvmDRFh38AeQgx1cELhKWc3P5ugtttraSwgH7nP2NUguO9nCrHuL6TZ-KWpmRWZqwH-jYKFQVt3CDpzwNM6XJL-oHbl1x-gI3YYX5w",
            "e": "AQAB",
            "x5c": [
                "MIIDBTCCAe2gAwIBAgIQZSAeaqWig4BHC1ksmNNcgjANBgkqhkiG9w0BAQsFADAtMSswKQYDVQQDEyJhY2NvdW50cy5hY2Nlc3Njb250cm9sLndpbmRvd3MubmV0MB4XDTE3MDUwNjAwMDAwMFoXDTE5MDUwNzAwMDAwMFowLTErMCkGA1UEAxMiYWNjb3VudHMuYWNjZXNzY29udHJvbC53aW5kb3dzLm5ldDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAJL7dVZkeJ8JDTPIzFNMJo9oEkvDc52zrdqWSOmex0E/3rBe1tfRmUe2O9l6NYuc10QzPaNxnkyIwa5698suNUPxGlEOwvm/h5oPeFcuxAWcgYYv5s589HWFrNjCF8EfOjZ4vU5oE1744EzxdmBiaGbeE8HDBXn1vK4owlcjawgQNF7KQ6LjSWr7xtARDF2IoKE4RYy0V0uVN4eAQ3zWRWWUt3cpYjTl34EZ9pO6CE8/If7noj75g0RYd/AHkIMdXBC4SlnNz+boLbba2ksIB+5z9jVILjvZwqx7i+k2filqZkVmasB/o2ChUFbdwg6c8DTOlyS/qB25dcfoCN2GF+cCAwEAAaMhMB8wHQYDVR0OBBYEFGKpXQNrF5IoxS6bL4F92+gxOJlIMA0GCSqGSIb3DQEBCwUAA4IBAQA3HgW5SoHlvvQVxqqi+mtscDZLhNfe13iG/nx8Er5il82b79RVydNs+f9sYxc4T4ctnrZu7x5e7jInJedNdAlrPorBdw+SfvKJsmiNndXugMew1FlcQTQVIFDCbziaJav8rKyMxPfeKkc1aixbajWZkKg6OPmmJn2ceTocbn8PMQy20xNvcWUwgF5FZZIuPqu6feOLJcUIYw+0JFZ265xka30QXpmytcIxajIzpD4PRdCIBuVSqgXacAs4t4+w+OhnosD72yvXck8M4GwX1j+vcuyw0yhDGNMmqsHWP7H3jnJiGDrKhhdVyplzDhTfv2Whbv/dIDn+meLE3yyC5yGL"
            ],
            "issuer": "https://login.microsoftonline.com/{tenantid}/v2.0"
        }

在JJWT我已经实现了SigningKeyResolver接口,我需要返回RSAPublicKey的实例做了验证。我遇到的问题是从JSON正确创建密钥。

难道我用的模数和指数开始?

BigInteger modulus = new BigInteger(1, Base64.decodeBase64(jsonKey.getN()));
BigInteger exponent = new BigInteger(1, Base64.decodeBase64(jsonKey.getE()));
publicKey = KeyFactory.getInstance("RSA").generatePublic(new RSAPublicKeySpec(modulus, exponent));

我开始与x5c,生成一个X509Certificate对象,并拉离那里的公钥?

CertificateFactory factory = CertificateFactory.getInstance("X.509");
X509Certificate cert = (X509Certificate) factory
          .generateCertificate(new ByteArrayInputStream(
           DatatypeConverter.parseBase64Binary(jsonKey.getX5c())));
publicKey = (RSAPublicKey)cert.getPublicKey();

这两种方法都徒劳无功。

如果我从生成系数和指数的RSAPublicKey我应该能够打印使用Base64Binary编码关键x5c属性相匹配?也许这不是我应该如何验证。

我可能误解了如何使用这个。

与往常一样,任何文件理解为好。

pedrofb:

x5c包含证书链。链的所述第一证书必须与由在JWK其他值所表示的键的值相匹配,在这种情况下ne,因此,公共密钥从提取x5c[0]与所述一个带内置ne必须是完全相同的

JWK值被编码在base64url,而不是用base64。更改

BigInteger modulus = new BigInteger(1, Base64.decodeBase64(jsonKey.getN()));
BigInteger exponent = new BigInteger(1, Base64.decodeBase64(jsonKey.getE()));

BigInteger modulus = new BigInteger(1, Base64.getUrlDecoder().decode(jsonKey.getN()));
BigInteger exponent = new BigInteger(1, Base64.getUrlDecoder().decode(jsonKey.getE()));

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

使用公钥验证签名

使用公钥节点验证签名

使用C#中的公钥验证用RS256算法签名的JWT

验证 JWT.io 签名 OneLogin ID Token 时使用什么公钥

如何使用Google的公钥手动验证JWT的签名?

仅使用公钥验证签名(C#)

使用.pem格式的公钥在Xcode中进行签名验证

Java使用公钥验证xml数字签名

Node JS JWT使用Google的公钥验证令牌

使用字符串中的公钥验证JWT

验证公钥与私钥签名是否匹配

尽管使用了正确的公钥和签名文件,但未验证签名

ECDSA使用Java的公钥和签名在C#中验证签名

当我使用gpg验证签名的文档时,它如何知道要使用的公钥?

公钥可以用于解密(验证)使用私钥加密(签名)的文档吗?

Golang:验证x509证书是否使用与指定公钥相对应的私钥签名

如何使用x509公钥来验证已签名/已哈希的Alexa请求正文?

在Apache Nifi中使用公钥进行RSA数字签名验证

在 C++ 中通过 openSSL 使用公钥验证 JWT 令牌时出现分段错误

Okta使用来自OpenID Connect配置的公钥验证JWT令牌

无法验证签名,因为公钥不可用

如何验证给定哈希和公钥的数字签名?

带有公钥的Microsoft Graph AccessToken签名验证

如何针对特定的公钥验证gpg签名的文件?

如何使用公钥验证 ECDSA?

如何使用 rsa 公钥验证文件

服务器如何验证JWT?公钥来自哪里?

如何共享OAuth2 JWT验证的公钥?

验证Veracrypt的公钥