在XSD中使用SAML断言

时间:2015-12-28 06:17:08

标签: java xsd axis2 saml-2.0 opensaml

我有一个webservice操作,我将获取SAML断言作为请求Body的一部分。 我有以下XSD:

<xsd:element name="CreateRequest">
    <xsd:complexType>
        <xsd:sequence>
            <xsd:element name="info" type="SomeRequestObj"/>
            <xsd:element ref="saml:Assertion" />
        </xsd:sequence>
    </xsd:complexType>
</xsd:element>

saml:断言是指:

 <xsd:import namespace="urn:oasis:names:tc:SAML:2.0:assertion"schemaLocation="../samlv2_0/saml-schema-assertion-2.0.xsd"/>

此saml架构是从 SAML 2.0 复制而来的。 这会生成名为* Type.java的类。 我很难为此创建一个单元测试(这是一个单独的UI应用程序)。

我的请求需要请求正文中的SAML AssertionType元素。 所以,我不能使用OpneSaml来生成它,因为它给了我一个SAML断言对象而不是AssertionType。

我尝试手动生成AssertionType对象,但我很难这样做 有没有办法使用OpenSaml来生成这个?
正如我所看到的那样,xml将与我在使用OpenSaml生成Assertion对象的情况下相同。 有没有办法简化这个?

编辑:添加了断言的XSD片段

<element name="Assertion" type="saml:AssertionType"/>
<complexType name="AssertionType">
<sequence>
<element ref="saml:Issuer"/>
<element ref="ds:Signature" minOccurs="0"/>
<element ref="saml:Subject" minOccurs="0"/>
<element ref="saml:Conditions" minOccurs="0"/>
<element ref="saml:Advice" minOccurs="0"/>
<choice minOccurs="0" maxOccurs="unbounded">
<element ref="saml:Statement"/>
<element ref="saml:AuthnStatement"/>
<element ref="saml:AuthzDecisionStatement"/>
<element ref="saml:AttributeStatement"/>
</choice>
</sequence>
<attribute name="Version" type="string" use="required"/>
<attribute name="ID" type="ID" use="required"/>
<attribute name="IssueInstant" type="dateTime" use="required"/>
</complexType>

这将生成AssertionType对象。

2 个答案:

答案 0 :(得分:3)

SAML断言的类型为“AssertionType”,但元素名称为“Assertion”。由OpenSaml生成的<Assertion>元素应该没问题。

该元素在SAML core spec中的2.3.3节中定义。

答案 1 :(得分:0)

使用JAXB从XSD生成类时,尝试使用外部绑定文件。看到这个主题(我猜它的第二个答案是你正在寻找的):JAXB: How to change XJC-generated classes names when attr type is specified in XSD?