在SAML LogoutRequest实例中设置会话索引

问题描述 投票:0回答:1

我试图通过LogoutRequest类使用opensaml库创建单一注销请求。没有方法在请求对象中设置Session索引。如何构建LogoutRequest?我用来构造请求对象的代码片段如下:

SAMLObjectBuilder<LogoutRequest> builder = (SAMLObjectBuilder<LogoutRequest>) builderFactory.getBuilder(LogoutRequest.DEFAULT_ELEMENT_NAME);

LogoutRequest request = builder.buildObject();
request.setID(generateID());
request.setVersion(SAMLVersion.VERSION_20);
request.setIssueInstant(new DateTime());
request.setDestination(bindingService.getLocation());

SAMLObjectBuilder<Issuer> issuerBuilder = (SAMLObjectBuilder<Issuer>) builderFactory.getBuilder(Issuer.DEFAULT_ELEMENT_NAME);
Issuer issuer = issuerBuilder.buildObject();
issuer.setValue(metadata.getHostedSPName());
request.setIssuer(issuer);

SAMLObjectBuilder<NameID> namdIDBuilder = (SAMLObjectBuilder<NameID>) builderFactory.getBuilder(NameID.DEFAULT_ELEMENT_NAME);
NameID nameid = namdIDBuilder.buildObject();
nameid.setFormat("urn:oasis:names:tc:SAML:2.0:nameid-format:transient");
request.setNameID(nameid);

SAMLObjectBuilder<SessionIndex> sessionIndexBuilder = (SAMLObjectBuilder<SessionIndex>) builderFactory.getBuilder(SessionIndex.DEFAULT_ELEMENT_NAME);
SessionIndex sessionindex = sessionIndexBuilder.buildObject();
sessionindex.setSessionIndex(sessionIndex);

如上所示,在构建SessionIndex之后,没有选项可以在LogoutRequest对象中进行设置。

有人可以给我一些示例或链接以使其正确吗?

single-sign-on saml-2.0 opensaml
1个回答
0
投票

我设法通过以下方式实现:

SessionIndex sessionIndex_ = (SessionIndex) Configuration.getBuilderFactory()
                                            .getBuilder(SessionIndex.DEFAULT_ELEMENT_NAME)
                                            .buildObject(SessionIndex.DEFAULT_ELEMENT_NAME);                
sessionIndex_.setSessionIndex("test");
request.getSessionIndexes()
       .add(sessionIndex_);
© www.soinside.com 2019 - 2024. All rights reserved.