4

この Perl コードは、ASP.NET Web サービスへの匿名アクセスで機能しますが、統合セキュリティがオンになっていると、サービスは 401 エラーを返します。SOAP::Lite と組み合わせて NTLM モジュールを使用する必要があると思いますが、その方法が明確ではありません。これらのコンポーネントはどのように統合できますか?

use SOAP::Lite;
use strict;

my $proxy = "http://localhost:28606/WebService.asmx";

my $method_name = "HelloWorld";
my $uri = "http://tempuri.org/";
my $methodAction = $uri . $method_name;

my $soap = SOAP::Lite
    ->uri( $uri )
    ->proxy( $proxy )
    ->on_action(sub{ $methodAction; });

my $method = SOAP::Data->name($method_name)->attr({xmlns=>$uri});
my $result = $soap->call($method);

print $result->result();
4

2 に答える 2

2

次のようにすると、SOAP::Lite にデバッグ出力を出力させることができます。

use SOAP::Lite +trace;

それ以外の

use SOAP::Lite;

編集:

わかりました、私は今それを得ると思います。統合セキュリティ機能をオンにすると、IIS で NTLM 認証が必要になります。perlmonks.orgに、答えを明らかにしているように見えるスレッドがあります。

于 2009-06-18T18:58:25.507 に答える
1

少し遅れましたが、同じ問題に直面しました。これを試して:

use LWP::UserAgent;
use LWP::Debug;
use SOAP::Lite on_action => sub { "$_[0]$_[1]"; };
import SOAP::Data 'name', 'value';
our $sp_endpoint = 'http://sp.example.com/sites/mysite/_vti_bin/lists.asmx';
our $sp_domain = 'sp.example.com:80';
our $sp_username = 'DOMAIN\username';
our $sp_password = 'xyz';

if ($debug) {
    LWP::Debug::level('+');
    SOAP::Lite->import(+trace => 'all');
}

my @ua_args = (keep_alive => 1);
my @credentials = ($sp_domain, "", $sp_usernam, $sp_password);
my $schema_ua = LWP::UserAgent->new(@ua_args);
$schema_ua->credentials(@credentials);
$soap = SOAP::Lite->proxy($sp_endpoint, @ua_args, credentials => \@credentials);
$soap->schema->useragent($schema_ua);
$soap->uri("http://schemas.microsoft.com/sharepoint/soap/");
于 2009-12-27T11:05:05.133 に答える