And*_*y A 5 proxy xmpp openfire socks xmppframework
问题:我正在尝试使用iOS XMPPFramework和OpenFire服务器进行TURN连接(XEP-0065).我希望能够发送和接收文件.但是,我收到503服务不可用的错误.
注意:我的代码基础来自以下教程: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>
Run Code Online (Sandbox Code Playgroud)
为什么会出错?
更新:XEP-0065说明如下.即使这个错误看起来与我的有点不同,它是否相关?如果是这样,问题是什么?
如果代理无法充当StreamHost,则代理必须向请求者返回错误,应该是请求者
<not-allowed/>.Run Code Online (Sandbox Code Playgroud)<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'.文档意味着我需要这个.这是问题吗?我没有看到代码中的当前方式来制作'来自'...
<iq type="get"
to="beta.myCompany.co.uk"
id="215784CF-81A8-403E-89BF-455C926BEAE5">
<query xmlns="http://jabber.org/protocol/disco#items"/>
</iq>
Run Code Online (Sandbox Code Playgroud)
更新19/04/12上午11:00:为了回应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>
Run Code Online (Sandbox Code Playgroud)
回应:
<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>
Run Code Online (Sandbox Code Playgroud)
发送:
<iq type="get"
to="proxy.beta.myCompany.co.uk"
id="F1B5370C-234F-4F2D-93E7-D60D2C35D063">
<query xmlns="http://jabber.org/protocol/disco#info"/>
</iq>
Run Code Online (Sandbox Code Playgroud)
回应:
<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>
Run Code Online (Sandbox Code Playgroud)
发送:
<iq type="get"
to="proxy.beta.myCompany.co.uk"
id="84904B7D-2BB2-4B8E-90BE-BE0F5A934764">
<query xmlns="http://jabber.org/protocol/bytestreams"/>
</iq>
Run Code Online (Sandbox Code Playgroud)
回应:
<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>
Run Code Online (Sandbox Code Playgroud)
另外我们还从查询代码中获取了一个streamhost,如下所示: 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"/>
Run Code Online (Sandbox Code Playgroud)
发送:
<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>
Run Code Online (Sandbox Code Playgroud)
这没有给出任何响应,但是当我与XEP-0065的示例17进行比较时,它看起来没问题.但是,如果不在传递给TurnSocket.m的jID中包含资源(friendsUsername@beta.myCompany.co.uk而不是friendsUsername@beta.myCompany.co.uk/spark),则此发送请求会相应更改
<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>
Run Code Online (Sandbox Code Playgroud)
并返回上面原始问题中的XML!(使用503错误代码).此外,我注意到这个xml包含'streamhost',但是在这个阶段它应该包含'streamhost-used'吗?为什么会出错?我应该或不应该将资源包含在'to'中?
次要更新 19/04/2012 15:07:我在OpenFire上添加了xmpp.proxy.transfer.required为false.这是由于这些讨论:这里和这里.我没有设置这个服务器(我的同事),我不明白这意味着什么,但它似乎没有对我的问题产生任何影响.
更新20/04/2012 10:00:当我不包含资源时,我认为我的503错误是正确的(根据此).即使这样,但我不确定为什么我没有得到完整的jID响应.