14

そのため、SUDSを使用してこのAPIhttps : //www.clarityaccounting.com/api-docs/にアクセスしようとしています。動作するはずのコードは次のとおりです。

from suds.client import Client
client = Client('https://www.clarityaccounting.com/api/v1?wsdl')
token = client.service.doLogin('demo', 'demo', 'www.kashoo.com', 'en_US', 300000)

しかし、私はこのエラーを受け取ります:

WebFault: Server raised fault: 'No such operation:  (HTTP GET PATH_INFO: /api/v1)'

彼らのサポート担当者は、リクエストは次のようになるはずだと言っています。

<SOAP-ENV:Envelope
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:api="http://api.service.books/">
  <SOAP-ENV:Body>
     <api:doLogin>
        <username>demo</username>
        <password>demo</password>
        <siteName>www.kashoo.com</siteName>
        <locale>en_US</locale>
        <duration>300000</duration>
     </api:doLogin>
  </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

しかし、SUDSは次のようになります。

<?xml version="1.0" encoding="UTF-8"?>
<SOAP-ENV:Envelope 
xmlns:ns0="http://api.service.books/" 
xmlns:ns1="http://schemas.xmlsoap.org/soap/envelope/" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/">
   <SOAP-ENV:Header/>
   <ns1:Body>
      <ns0:doLogin>
         <username>demo</username>
         <password>demo</password>
         <siteName>www.kashoo.com</siteName>
         <locale>en_US</locale>
         <duration>300000</duration>
      </ns0:doLogin>
   </ns1:Body>
</SOAP-ENV:Envelope>

私は本当のSOAPとSUDSの初心者ですが、ここから使用するのにSUDSが最適なSOAPライブラリであると聞きました。Python用にどのSOAPクライアントライブラリが存在し、それらのドキュメントはどこにありますか?

だから私の質問は、要求を失敗させている異なる重要な部分は何ですか?適切にフォーマットされた要求を送信するようにSUDSを構成するにはどうすればよいですか?

4

3 に答える 3

37

一見すると、SSLに問題があるように見えます。https URLにアクセスしており、suds.clientのトランスポートハンドラーはデフォルトでhttpと通信します。

問題
WSDLの下部を見ると、デフォルトの場所http://www.clarityaccounting.com/api/v1がhttp URLとして指定されていますが、WSDLはSSLです。

 <wsdl:service name="v1">
    <wsdl:port binding="tns:v1SoapBinding" name="BooksApiV1Port">
      <soap:address location="http://www.clarityaccounting.com/api/v1"/>
    </wsdl:port>
 </wsdl:service>

そのURLでhttpGETを実行すると、次のエラーメッセージが表示されます。

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
    <soap:Body>
        <soap:Fault>
            <faultcode>soap:Server</faultcode>
            <faultstring>No such operation:  (HTTP GET PATH_INFO: /api/v1)</faultstring>
        </soap:Fault>
    </soap:Body>
</soap:Envelope>

解決策これを修正するには、コンストラクターを呼び出してhttps
に固定するときに、デフォルトの場所をオーバーライドする必要があります。Client

>>> url
'https://www.clarityaccounting.com/api/v1?wsdl'
>>> client = Client(url, location='https://www.clarityaccounting.com/api/v1')
>>> token = client.service.doLogin('demo', 'demo', 'www.kashoo.com', 'en_US', 300000)
>>> token
(authToken){
   authenticationCode = "ObaicdMJZY6UM8xZ2wzGjicT0jQ="
   expiryDate = 2010-03-05 12:31:41.000698
   locale = "en_US"
   myUserId = 4163
   site = "www.kashoo.com"
 }

勝利!

将来のデバッグのためのプロのヒント:完全なロギングデバッグをオンにします。SUDSは標準loggingライブラリを使用するため、多くの制御が可能です。だから私はそれをすべてクランクアップしましたDEBUG

import logging
logging.basicConfig(level=logging.INFO)
logging.getLogger('suds.client').setLevel(logging.DEBUG)
logging.getLogger('suds.transport').setLevel(logging.DEBUG)
logging.getLogger('suds.xsd.schema').setLevel(logging.DEBUG)
logging.getLogger('suds.wsdl').setLevel(logging.DEBUG)

これは、httpを送信していることを明確に示していたため、これを絞り込むのに役立ちました。

DEBUG:suds.transport.http:sending:
URL:http://www.clarityaccounting.com/api/v1
(xml output omitted)

そして、応答もそう言った:

DEBUG:suds.client:http failed:
于 2010-03-05T17:19:10.743 に答える
2

維持されているsudのフォークであるsuds-jurkohttps://pypi.python.org/pypi/suds-jurkoを使用します。送信する生のxmlを指定できる__injectオプションを渡すことができます。

from suds.client import Client

username, password, sitename, locale, duration = 'demo', 'demo', 'www.kashoo.com', 'en_US', 300000

raw_xml = """<SOAP-ENV:Envelope
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:api="http://api.service.books/">
  <SOAP-ENV:Body>
     <api:doLogin>
        <username>{0}</username>
        <password>{1}</password>
        <siteName>{2}</siteName>
        <locale>{3}</locale>
        <duration>{4}</duration>
     </api:doLogin>
  </SOAP-ENV:Body>
</SOAP-ENV:Envelope>""".format(username, password, sitename, locale, duration)

client = Client(url, location)
result = client.service.doLogin(__inject={'msg':raw_xml})

ここで泡が発生する生石鹸を検査する方法をすべて文書化する必要があると思います。

  1. クライアントを構築するときにnosendフラグを使用します。フラグをTrueに設定すると、sudは石鹸を生成するだけで、送信しないことに注意してください。

    client =Client(url, nosend=True)
    res = client.service.example()
    print res.envelope#生石鹸を印刷します

  2. ロギングの使用。ここではsuds.transport.httpのみをログに記録しているため、送受信されたものだけが出力されます。

    import logging
    import sys
    handler = logging.StreamHandler(sys.stderr)
    logger = logging.getLogger('suds.transport.http')
    logger.setLevel(logging.DEBUG), handler.setLevel(logging.DEBUG)
    logger.addHandler(handler)

  3. MessagePluginの使用

    from suds.plugin import MessagePlugin
    class MyPlugin(MessagePlugin):
    def marshalled(self, context):
    #import pdb; pdb.set_trace()
    print context.envelope.str()

    client = Client(url, plugins=[MyPlugin()])

MessagePluginは、生成された石鹸を検査する機能を提供するだけでなく、送信する前にそれを変更することもできます。参照-> https://jortel.fedorapeople.org/suds/doc/suds.plugin.MessagePlugin-class.html

于 2014-10-30T10:00:26.657 に答える
1

HTTPS経由でのサービスへの接続に関連する問題ではないはずです。私は同じことをするために泡を使っています。私はあなたのWSDLファイル(私自身は専門家ではありません)へのいくつかのアプローチを試しましたが、同じエラーが発生しました。ファクトリメソッドを使用することですが、泡を使って練習する必要があります。

login = client.factory.create('doLogin')
login.username = 'username'
etc...

create関数に送信されるものは、WSDLファイルで定義されているタイプの1つです。シェルでそのタイプを作成する場合は、「print login」を実行して、追加のプロパティを確認できます。

これが少なくとも問題がどこにないかを教えてくれることを願っています(HTTPSの場合)。また、soapActionヘッダーがWSDLファイルに設定されていないことに気付きました。これがないと、sudsまたはサービスがリクエストを処理する方法がわかりません。

于 2010-03-05T20:36:30.657 に答える