WSS4J 1.6 と Axis 1.4 を使用しています。
org.apache.ws.security.message.WSSecUsernameToken を使用して UsernameToken を作成しています。
私が理解していないのはwsu:Id属性です。Web サービスの仕様によると、「SecurityToken-24ada6f8-4626-4269-b786-a22361bfde78」の形式である必要があります。
私が何をしても、wsu:Id属性には「UsernameToken-123」が含まれていますが、Web サービスの仕様によれば、「SecurityToken-24ada6f8-4626-4269-b786-a22361bfde78」の形式にする必要があります。
これを達成する方法がまったくわからず、Googleは枯渇しています。
それで、誰か私が何をする必要があるか教えてもらえますか?
付属の UsernameToken xml は現在のものです。
<wsse:UsernameToken wsu:Id="UsernameToken-133"
xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"
xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
<wsse:Username>stan</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">secrit</wsse:Password>
</wsse:UsernameToken>
UsernameToken xml を出してほしい。
<wsse:UsernameToken wsu:Id="SecurityToken-24ada6f8-4626-4269-b786-a22361bfde78"
xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"
xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
<wsse:Username>stan</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">secrit</wsse:Password>
</wsse:UsernameToken>
SOAP メッセージの作成に使用するコードを次に示します。
public String soapTest() throws Exception {
MessageFactoryImpl messageFactory = new MessageFactoryImpl();
SOAPMessage soapMessage = null;
soapMessage = messageFactory.createMessage();
Message message = (Message)soapMessage;
SOAPEnvelope unsignedEnvelope = message.getSOAPEnvelope();
unsignedEnvelope.addNamespaceDeclaration( "xsd", "http://www.w3.org/2001/XMLSchema" );
unsignedEnvelope.addNamespaceDeclaration( "xsi", "http://www.w3.org/2001/XMLSchema-instance" );
unsignedEnvelope.addNamespaceDeclaration( "enc", "http://schemas.xmlsoap.org/soap/encoding/" );
unsignedEnvelope.addNamespaceDeclaration( "env", "http://schemas.xmlsoap.org/soap/envelop/" );
unsignedEnvelope.addNamespaceDeclaration( "wsa", "http://schemas.xmlsoap.org/ws/2004/03/addressing" );
unsignedEnvelope.addNamespaceDeclaration( "wsse", "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" );
unsignedEnvelope.addNamespaceDeclaration( "wsu", "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" );
unsignedEnvelope.addNamespaceDeclaration( "ws", "http://ws.stupidsoap.com" );
SOAPBody soapMsgBody = (SOAPBody)soapMessage.getSOAPBody();
org.apache.axis.message.SOAPEnvelope soapMsgEnvelope = ((Message)soapMessage).getSOAPEnvelope();
SOAPBodyElement be = (SOAPBodyElement)soapMsgBody.addChildElement( soapMsgEnvelope.createName( "addTwoNumbers", "", "http://ws.stupidsoap.com" ) );
be.addChildElement( "number1" ).addTextNode( "5" );
be.addChildElement( "number2" ).addTextNode( "10" );
org.w3c.dom.Document doc = (org.w3c.dom.Document)soapMsgEnvelope.getAsDocument();
WSSecHeader secHeader = new WSSecHeader();
secHeader.insertSecurityHeader( doc );
WSSecUsernameToken utBuilder = new WSSecUsernameToken();
utBuilder.setPasswordType( WSConstants.PASSWORD_TEXT );
utBuilder.setUserInfo( "stan", "secrit" );
utBuilder.addNonce();
utBuilder.addCreated();
utBuilder.build( doc, secHeader );
return org.apache.ws.security.util.XMLUtils.PrettyDocumentToString( doc );
}