1

SudzC を使用して WebService Client を作成していますが、設定などを何度か試みた後、データを返すことができました。サービス内でロギングをオンにすると、以下に示すように応答ログが記録されます。(すべての XML タグにスペースを追加して、StackOverflow 内で印刷できるようにしました。XML が機能することを受け入れてください。このデータを JAXB オブジェクトに取得し、現在動作する既存の Java アプリケーションがあるためです。)

 2012-03-13 11:21:43.936 SampleProject[976:f803] 
< SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" >
    < SOAP-ENV:Header/ >
    < SOAP-ENV:Body >
        < ns2:GetDevicesResponse xmlns:ns2="http://somesite.com/cayman/schemas" >
            < ns2:Devices>
                < ns2:DeviceName>Neelam 65< /ns2:DeviceName>
                < ns2:DeviceName>Neelam 66< /ns2:DeviceName>
            < /ns2:Devices>
        < /ns2:GetDevicesResponse>
    < /SOAP-ENV:Body>
< /SOAP-ENV:Envelope>

ただし、デリゲートを使用しようとすると、OR
[service GetDevices:self action:@selector(handleFind:)];
「結果」の値は常に nil です。

何か案は?

XpressViewViewController.h

@interface XpressViewViewController : UIViewController <SoapDelegate>

...

XpressViewViewController.m

@implementation XpressViewViewController

...

- (IBAction)initiateService:(id)sender {

    CaymanService* service = [[CaymanService alloc]init];

    service.logging = YES;

    NSMutableDictionary * headers = [[NSMutableDictionary alloc]init];
    SoapLiteral *soapLiteral =[SoapLiteral literalWithString: @"<wsse:Security xmlns:wsse=\"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd\"><wsse:UsernameToken xmlns:wsu=\"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd\"><wsse:Username>DUMMY</wsse:Username><wsse:Password Type=\"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText\">test</wsse:Password></wsse:UsernameToken></wsse:Security>"];

    [headers setValue:soapLiteral forKey:@"header"]; 

    [service setHeaders: headers];

    [service setNamespace:@"http://company.com/cayman/schemas"];

    //SoapRequest *sr = [service GetDevices:self action:@selector(handleFind:)];
    //NSLog(@"Request: ", sr.description);

    [service GetDevices:self];
}

     - (void) onload: (id) result;
{
    //Why are you ALWAYS nil...What am I missing???
    NSLog(@"Data: %@", result);
}

 - (void) onerror: (NSError*) error;
{
    NSLog(@"Error: %@", error);
}
 - (void) onfault: (SoapFault*) fault;
{
    NSLog(@"Fault: %@", fault);    
}
-(void)handleFind: (id) result {
    if([result isKindOfClass: [NSError class]]) {
        NSLog(@"Error: %@",result);
        return;
    }

    if([result isKindOfClass: [SoapFault class]]) { 
        NSLog(@"Error: %@",result);

        return;
    }

    // This doesn't matter because result is ALWAYS nil
    NSArray *data = [[NSArray alloc ]initWithArray: result];
    NSLog(@"We have %@ devices ", [NSNumber numberWithInt:data.count]);
}
4

1 に答える 1

2

私は同様の問題を抱えていましたが、このリンクで概説されている解決策が役立ちました: http://code.google.com/p/sudzc/issues/detail?id=40

基本的に、SudzC にはまだパッチが適用されていないバグがあるようですが、Soap.m ファイルを 1 行変更するだけで回避できます。

于 2012-04-24T08:07:11.897 に答える