問題:iOS XMPPFrameworkとOpenFireサーバーを使用してTURN接続(XEP-0065)を試みています。ファイルを送受信できるようにしたい。ただし、503service-unavailableエラーが発生します。
注:私のコードのベースは、次のチュートリアルからのものです:http: //mobile.tutsplus.com/tutorials/iphone/building-a-jabber-client-for-ios-server-setup/
XMLエラー:
TURNSocket.mを介してデバッグしました。これはprocessRequestResponseに入り、次のXMLを持ちます。(私が間違っていない場合、これはOpenFireから私に送信されたものであり、その逆ではありませんか?)...
<iq xmlns="jabber:client"
type="error"
id="03CC977E-2645-4E87-AE78-536D985CA2B5"
from="friendsUsername@beta.myCompany.co.uk"
to="myUsername@beta.myCompany.co.uk/12f10b69">
<query xmlns="http://jabber.org/protocol/bytestreams"
sid="03CC977E-2645-4E87-AE78-536D985CA2B5"
mode="tcp">
<streamhost jid="proxy.beta.myCompany.co.uk"
host="127.0.1.1"
port="7777"/>
</query>
<error code="503"
type="cancel">
<service-unavailable xmlns="urn:ietf:params:xml:ns:xmpp-stanzas"/>
</error>
</iq>
なぜエラーが発生するのですか?
更新:XEP-0065は次のように述べています。このエラーは私のものとは少し異なって見えますが、関連性がありますか?もしそうなら、問題は何ですか?
プロキシがStreamHostとして機能できない場合、プロキシはリクエスターにエラーを返さなければなりません。これはである必要があります
<not-allowed/>
。<iq from='requester@example.com/foo' id='uj2c15z9' to='streamer.example.com' type='error'> <error type='cancel'> <not-allowed xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/> </error> </iq>
更新:現時点では、XMLのさまざまな送信および取得ビットにJIDリソースを含めるか除外するかが問題であるかどうかを調べています。または、次のxmlに「from」もありません。ドキュメントは私がこれを必要としていることを暗示しています。これは問題ですか?'from'を作成するコードの現在の方法がわかりません...
<iq type="get"
to="beta.myCompany.co.uk"
id="215784CF-81A8-403E-89BF-455C926BEAE5">
<query xmlns="http://jabber.org/protocol/disco#items"/>
</iq>
更新19/04/1211 :00am :Matt Jの応答に応じて、さらにXMLを投稿しています。Mattが送信および取得されたものの完全なXMLログを要求したかどうかはわかりませんが、念のため、ここにあります。これらのログはすべて同じランスルーからのものではないことに注意してください(XMLログを取得するためにデバッグするとタイムアウトが発生するため、最初からやり直す必要があります)
送信済み:
<iq type="get" to="beta.myCompany.co.uk"
id="082A1987-384F-43CD-9E7B-A2C0E31F2CA8">
<query xmlns="http://jabber.org/protocol/disco#items"/>
</iq>
応答:
<iq xmlns="jabber:client"
type="result"
id="18EED477-B0E4-492D-89CF-CA692FCF13AD"
from="beta.myCompany.co.uk"
to="myUsername@beta.myCompany.co.uk/72d23cd0">
<query xmlns="http://jabber.org/protocol/disco#items">
<item jid="pubsub.beta.myCompany.co.uk"
name="Publish-Subscribe service"/>
<item jid="broadcast.beta.myCompany.co.uk"
name="Broadcast service"/>
<item jid="search.beta.myCompany.co.uk"
name="User Search"/>
<item jid="conference.beta.myCompany.co.uk"
name="Public Chatrooms"/>
<item jid="proxy.beta.myCompany.co.uk"
name="Socks 5 Bytestreams Proxy"/>
</query>
</iq>
送信済み:
<iq type="get"
to="proxy.beta.myCompany.co.uk"
id="F1B5370C-234F-4F2D-93E7-D60D2C35D063">
<query xmlns="http://jabber.org/protocol/disco#info"/>
</iq>
応答:
<iq xmlns="jabber:client"
type="result"
id="F1B5370C-234F-4F2D-93E7-D60D2C35D063"
from="proxy.beta.myCompany.co.uk"
to="myUsername@beta.myCompany.co.uk/32276f6">
<query xmlns="http://jabber.org/protocol/disco#info">
<identity category="proxy"
name="SOCKS5 Bytestreams Service"
type="bytestreams"/>
<feature var="http://jabber.org/protocol/bytestreams"/>
<feature var="http://jabber.org/protocol/disco#info"/>
</query>
</iq>
送信済み:
<iq type="get"
to="proxy.beta.myCompany.co.uk"
id="84904B7D-2BB2-4B8E-90BE-BE0F5A934764">
<query xmlns="http://jabber.org/protocol/bytestreams"/>
</iq>
応答:
<iq xmlns="jabber:client"
type="result"
id="B412512B-FA27-4531-88BE-2FC0A26E6ED2"
from="proxy.beta.myCompany.co.uk"
to="myUsername@beta.myCompany.co.uk/45ca808d">
<query xmlns="http://jabber.org/protocol/bytestreams"/>
</iq>
さらに、次のようなクエリのコードからストリームホストを取得します。NSXMLElement *streamhost = [query elementForName:@"streamhost"];
<streamhost xmlns="http://jabber.org/protocol/bytestreams"
jid="proxy.beta.myCompany.co.uk"
host="127.0.1.1"
port="7777"/>
送信済み:
<iq type="set"
to="friendsUsername@beta.myCompany.co.uk/spark"
id="DD96A581-BFA3-47BC-A3C0-D26AD48D7442">
<query xmlns="http://jabber.org/protocol/bytestreams"
sid="DD96A581-BFA3-47BC-A3C0-D26AD48D7442"
mode="tcp">
<streamhost xmlns="http://jabber.org/protocol/bytestreams"
jid="proxy.beta.myCompany.co.uk"
host="127.0.1.1"
port="7777"/>
</query>
</iq>
これは応答しませんが、XEP-0065の例17と比較すると、問題ないように見えます。ただし、TurnSocket.m(friendsUsername@beta.myCompany.co.uk/sparkではなくfriendsUsername@beta.myCompany.co.uk)に渡されるjIDにリソースを含めない場合、この送信要求は適切に変更されます。
<iq type="set"
to="friendsUsername@beta.myCompany.co.uk" **LOOK! NO RESOURCE!**
id="5D08B85E-CA78-4AA8-A893-C1DC571A9808">
<query xmlns="http://jabber.org/protocol/bytestreams"
sid="5D08B85E-CA78-4AA8-A893-C1DC571A9808"
mode="tcp">
<streamhost xmlns="http://jabber.org/protocol/bytestreams"
jid="proxy.beta.myCompany.co.uk"
host="127.0.1.1"
port="7777"/>
</query>
</iq>
上記の元の質問のXMLが返されます!(503エラーコード付き)。さらに、このxmlには「streamhost」が含まれていることに気付きましたが、この段階では実際に「streamhost-used」を含める必要がありますか?なぜエラーが発生するのですか?'to'にリソースを含めるべきかどうか。
マイナーアップデート19/04/201215 :07:OpenFireでxmpp.proxy.transfer.requiredをfalseとして追加しました。これは、これらの議論によるものです:こことここ。私はこのサーバーをセットアップしていませんでした(私の同僚はセットアップしました)、そしてそれが何を意味するのか理解していませんが、それは私の問題に何の違いももたらさなかったようです。
更新20/04/201210:00 :リソースを含めない場合(これによると)、私の503エラーは正しく存在すると思います。たとえそうだとしても、完全なjIDで応答がない理由はわかりません。