November 2019

S M T W T F S
      12
34 5 678 9
10111213141516
17181920212223
24252627282930

Style Credit

Expand Cut Tags

No cut tags
Tuesday, April 22nd, 2008 05:41 pm
Покажите, пожалуйста, пальцем, где у меня ошибка в ДНК. Или не у меня, а в SOAP::Lite.
А то я уже голову сломал.

Дано: простейший тестовый скрипт о пяти строчках.
#!/usr/bin/perl -w
use SOAP::Lite +trace => "debug";
my $service = SOAP::Lite
-> service('http://...');
$service->envprefix('SOAP-ENV');

my $r = $service->Version();


Во всех инструкциях написано, что вызов метода, даже неудачный, должен вернуть ссылку на SOAP::SOM, после чего можно по ней получать всякие fault, result и paramsout.

Авотфиг. Вызов проходит, я в дампе вижу, что сервер понял запрос и вернул корректный XML. А в $r возвращается скалярная единица.

Аналогичная фигня с попыткой передать в вызываемый метод ссылки на SOAP::Data, как показано в документации. Оно говорит String value expected instead of SOAP::Data reference.

А $service->call('Version') говорит, что "A service address has not been specified either by using SOAP::Lite->proxy() or a service description)", хотя в вышеуказанном явном вызове $service->Version() адрес прокси замечательно обнаруживается.

Сдаётся мне, что я не замечаю каких-то больших граблей, но каких?

P.S. libsoap-lite-perl 0.69-1 в убунте, если что.
Tags:
Tuesday, April 22nd, 2008 05:01 pm (UTC)
Во всех инструкциях написано, что вызов метода, даже неудачный, должен вернуть ссылку на SOAP::SOM
Я SOAP::Lite давно использую и мои методы всегда возвращали скалярные величины. Может, они что-то переделали и в 0.69-1 этого нету?

Сдаётся мне, что я не замечаю каких-то больших граблей, но каких?
SOAP::Lite - это вообще одни большие грабли, без чтения исходников их логику не всегда можно понять.
Edited 2008-04-22 05:01 pm (UTC)
Tuesday, April 22nd, 2008 05:14 pm (UTC)
хм. а как ты получаешь результаты, если их больше одного?

и потом, может, я как-то неправильно понимаю, чтО тут нарисовано?
http://guide.soaplite.com/#error%20handling
http://guide.soaplite.com/#writing%20a%20client - конкретно вот тут: http://guide.soaplite.com/hibyeout.pl_

Ну и, собственно, из perldoc SOAP::SOM от конкретно установленной у меня на машине версии:
SOAP::SOM objects are returned by a SOAP::Lite call in a client context. For example:

my $client = SOAP::Lite
->readable(1)
->uri($NS)
->proxy($HOST)
$som = $client->someMethod();


Tuesday, April 22nd, 2008 05:48 pm (UTC)
Да мне как-то не нужно было больше одного. Но я напутал, да, скалярные у меня возвращают не сами методы, а result у них:

print $soap
        -> chpass(...)
        -> result();


Через переменную, как my $r у тебя, никогда не пробовал.

Но ты вроде все правильно делаешь.
Tuesday, April 22nd, 2008 05:07 pm (UTC)
Попробуй указать proxy(), как они просят. У меня, например, так:
$soap = SOAP::Lite
        -> uri('system')
        -> proxy('tcp://'.$server.':'.@conn_to[1]);


Для HTTP синтаксис скорее всего немного другой.
Tuesday, April 22nd, 2008 06:34 pm (UTC)
ref точно SCALAR говорит?
Wednesday, April 23rd, 2008 12:40 pm (UTC)
print Dumper($r);
дает
$VAR1 = '1';

по-моему, это типичный скаляр.
Wednesday, April 23rd, 2008 01:02 pm (UTC)
а если написать так:

my @data = $service->Version();
Wednesday, April 23rd, 2008 01:40 pm (UTC)
Спасибо, стало интереснее.
$VAR1 = '1';
$VAR2 = 'EmrSOAP 4.6.0 on SITE2-AS02';
$VAR3 = '';

Действительно, соответствует XMLному

<Result>1</Result><strVersion>EmrSOAP 4.6.0 on SITE2-AS02</strVersion><strResult></strResult>

Но почему оно не SOM, как в документации написано?
Wednesday, April 23rd, 2008 02:48 pm (UTC)
я не знаю, мне лично SOAP показался тяжеловесным, я им практически не занимался, пользовал XMLRPC для удаленных вызовов.

интересно может он на хэш еще что-то интересное вернет? %d = ..
perl ведь может определять рантайм что стоит слева и возвращать то, что требуют.
или какой глобальную переменную выставить.



Thursday, April 24th, 2008 09:41 am (UTC)
хэш получился исключительно кривой:

Odd number of elements in hash assignment at ./soaptest.pl line 23.
$VAR1 = '';
$VAR2 = undef;
$VAR3 = '1';
$VAR4 = 'EmrSOAP 4.6.0 on SITE2-AS02';
(deleted comment)
Wednesday, March 3rd, 2010 10:04 am (UTC)
увы, только в исходниках. документация от них заметно отличается