Opensaml xmlns не генерируется для имен IDPolicy и AuthnContext

Привет, я хочу, чтобы мой XML выглядит так:

<samlp:NameIDPolicy 
    xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol"
    Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"
    AllowCreate="true">
</samlp:NameIDPolicy>

моя установка с opensaml:

// NameIDPolicy
nameIdPolicyBuilder = new NameIDPolicyBuilder();
nameIdPolicy = nameIdPolicyBuilder.buildObject("urn:oasis:names:tc:SAML:2.0:protocol", "NameIDPolicy", "samlp");
nameIdPolicy.setFormat("urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress");
nameIdPolicy.setAllowCreate(new Boolean(true));

// Creation of AuthRequestObject
issueInstant = new DateTime();
authRequestBuilder = new AuthnRequestBuilder();
authRequest = authRequestBuilder.buildObject("urn:oasis:names:tc:SAML:2.0:protocol", "AuthnRequest", "samlp");
authRequest.setForceAuthn(new Boolean(false));
authRequest.setIsPassive(new Boolean(false));
authRequest.setIssueInstant(issueInstant);
authRequest.setProtocolBinding("urn:oasis:names:tc:SAML:2.0:bindings:HTTP-POST");
authRequest.setAssertionConsumerServiceURL(consumerUrl);
authRequest.setIssuer(issuer);
authRequest.setNameIDPolicy(nameIdPolicy);
authRequest.setRequestedAuthnContext(requestedAuthnContext);

но результат таков:

<samlp:NameIDPolicy 
    AllowCreate="true" 
    Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress" />

То же самое происходит с объектом AuthnContext.

Код, который я использую для кодирования запроса:

private String encodeAuthnRequest(AuthnRequest authnRequest) throws MarshallingException, IOException {

    org.opensaml.core.xml.io.Marshaller marshaller = null;
    org.w3c.dom.Element authDOM = null;
    java.io.StringWriter requestWriter = null;
    String requestMessage = null;
    java.util.zip.Deflater deflater = null;
    java.io.ByteArrayOutputStream byteArrayOutputStream = null;
    java.util.zip.DeflaterOutputStream deflaterOutputStream = null;
    String encodedRequestMessage = null;


    marshaller = XMLObjectProviderRegistrySupport.getMarshallerFactory().getMarshaller(authnRequest.getElementQName());


    authDOM = marshaller.marshall(authnRequest); // converting to a DOM

    requestWriter = new StringWriter();
    org.opensaml.xml.util.XMLHelper.writeNode(authDOM, requestWriter);
    requestMessage = requestWriter.toString(); // DOM to string

    deflater = new Deflater(Deflater.DEFLATED, true);
    byteArrayOutputStream = new ByteArrayOutputStream();
    deflaterOutputStream = new DeflaterOutputStream(byteArrayOutputStream, deflater);
    deflaterOutputStream.write(requestMessage.getBytes()); // compressing
    deflaterOutputStream.close();

    encodedRequestMessage = org.opensaml.xml.util.Base64.encodeBytes(byteArrayOutputStream.toByteArray(), org.opensaml.xml.util.Base64.DONT_BREAK_LINES);
    encodedRequestMessage = URLEncoder.encode(encodedRequestMessage, "UTF-8").trim(); // encoding
                                                                                        // string

    return encodedRequestMessage;

}

0 ответов

Другие вопросы по тегам