AuthnRequest未被签名
创始人
2024-09-22 15:30:20
0

要解决"AuthnRequest未被签名"的问题,你需要对AuthnRequest进行签名。下面是一个使用Java和OpenSAML库的示例代码,用于创建和签名一个AuthnRequest。

首先,确保你已经在项目中添加了OpenSAML依赖。你可以在Maven项目中添加以下依赖项:


    org.opensaml
    opensaml-core
    3.4.1


    org.opensaml
    opensaml-saml-api
    3.4.1


    org.opensaml
    opensaml-saml-impl
    3.4.1

接下来,你可以使用以下代码创建和签名一个AuthnRequest:

import org.joda.time.DateTime;
import org.opensaml.core.config.Configuration;
import org.opensaml.core.config.InitializationService;
import org.opensaml.core.xml.io.MarshallingException;
import org.opensaml.saml.common.SAMLObjectBuilder;
import org.opensaml.saml.common.xml.SAMLConstants;
import org.opensaml.saml.saml2.core.AuthnContextClassRef;
import org.opensaml.saml.saml2.core.AuthnRequest;
import org.opensaml.saml.saml2.core.Issuer;
import org.opensaml.security.SecurityException;
import org.opensaml.xmlsec.SignatureSigningConfiguration;
import org.opensaml.xmlsec.SignatureSigningParameters;
import org.opensaml.xmlsec.config.DefaultSecurityConfigurationBootstrap;
import org.opensaml.xmlsec.keyinfo.KeyInfoGenerator;
import org.opensaml.xmlsec.keyinfo.KeyInfoGeneratorFactory;
import org.opensaml.xmlsec.keyinfo.KeyInfoGeneratorManager;
import org.opensaml.xmlsec.keyinfo.NamedKeyInfoGeneratorManager;
import org.opensaml.xmlsec.signature.KeyInfo;
import org.opensaml.xmlsec.signature.KeyInfoGeneratorManagerFactory;
import org.opensaml.xmlsec.signature.Signature;
import org.opensaml.xmlsec.signature.support.SignatureConstants;
import org.opensaml.xmlsec.signature.support.Signer;

import javax.xml.namespace.QName;

public class AuthnRequestSigner {

    public static void main(String[] args) throws Exception {
        // 初始化OpenSAML配置
        InitializationService.initialize();

        // 创建AuthnRequest对象
        AuthnRequest authnRequest = createAuthnRequest();

        // 对AuthnRequest进行签名
        signAuthnRequest(authnRequest);

        // 输出签名后的AuthnRequest
        System.out.println(XMLUtils.marshall(authnRequest));
    }

    private static AuthnRequest createAuthnRequest() {
        // 创建SAML对象构建器
        SAMLObjectBuilder authnRequestBuilder = (SAMLObjectBuilder) Configuration.getBuilderFactory().getBuilder(AuthnRequest.DEFAULT_ELEMENT_NAME);
        SAMLObjectBuilder issuerBuilder = (SAMLObjectBuilder) Configuration.getBuilderFactory().getBuilder(Issuer.DEFAULT_ELEMENT_NAME);
        SAMLObjectBuilder authnContextClassRefBuilder = (SAMLObjectBuilder) Configuration.getBuilderFactory().getBuilder(AuthnContextClassRef.DEFAULT_ELEMENT_NAME);

        // 创建AuthnRequest对象
        AuthnRequest authnRequest = authnRequestBuilder.buildObject();
        authnRequest.setID("_" + String.valueOf(new DateTime().getMillis()));
        authnRequest.setVersion(SAMLVersion.VERSION_2_0);
        authnRequest.setIssueInstant(new DateTime());
        authnRequest.setDestination("https://example.com/destination");
        authnRequest.setProtocolBinding(SAMLConstants.SAML2_POST_BINDING_URI);

        // 设置Issuer
        Issuer issuer = issuerBuilder.buildObject();
        issuer.setValue("https://example.com/issuer");
        authnRequest.setIssuer(issuer);

        // 设置AuthnContextClassRef
        AuthnContextClassRef authnContextClassRef = authnContextClassRefBuilder.buildObject();
        authnContextClassRef.setAuthnContextClassRef(AuthnContext.PASSWORD_AUTHN_CTX);
        authnRequest.setRequestedAuthnContext(authnContextClassRef);

        return authnRequest;
    }

    private static void signAuthnRequest(AuthnRequest authnRequest) throws SecurityException, MarshallingException {
        // 获取默认的签名配置
        SignatureSigningConfiguration signingConfig = DefaultSecurityConfigurationBootstrap.buildDefaultSignatureSigningConfiguration();

        // 创建签名参数

相关内容

热门资讯

十分钟带你辅助!哥哥打大a辅助... 十分钟带你辅助!哥哥打大a辅助工具,心悦填大坑辅助,细节方法(发现有挂)-哔哩哔哩 了解更多开挂安装...
玩家攻略推荐"途游辅... 《玩家攻略推荐"途游辅助软件"开挂(透视)辅助软件(其实是有挂)-哔哩哔哩》 途游辅助软件软件透视开...
五分钟带你了解!来来拼十辅助(... 五分钟带你了解!来来拼十辅助(辅助挂)一分钟快速了解外挂开挂辅助脚本(原来是有挂)来来拼十辅助ai黑...
两分钟带你科普!传送屋激k看底... 传送屋激k看底牌辅助软件是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可...
一起来讨论"新畅游互... 一起来讨论"新畅游互娱辅助app"开挂(透视)辅助安装(其实确实是有挂的)-哔哩哔哩;1、不需要AI...
第一分钟带你了解!大唐山西辅助... 第一分钟带你了解!大唐山西辅助软件苹果版(透视挂)一分钟揭秘外挂开挂辅助神器(一贯有挂);无需打开直...
九分钟带你讲解!三加一免费辅助... 您好:这款小程序牵手跑的辅助游戏是可以开挂的,确实是有挂的,很多玩家在这款小程序牵手跑的辅助游戏中打...
透视app"新蜜瓜大... 【福星临门,好运相随】;透视app"新蜜瓜大厅免费控制器"开挂(透视)辅助插件(果然是有挂的)-哔哩...
第四分钟带你了解!朋友圈app... 大家好,今天小编来为大家解答朋友圈app辅助软件这个问题咨询软件客服可以免费测试直接加微信(1367...
七分钟带你辅助!新九哥脚本,越... 七分钟带你辅助!新九哥脚本,越乡游义乌辅助器下载,黑科技教程(的确有挂)-哔哩哔哩;无需打开直接搜索...