的Openfire / XMPP 503服务不可用的错误(使用的是iOS XMPPFramework

2019-06-23 17:45发布

问题 :我尝试使用了iOS XMPPFramework和Openfire的服务器一转接线(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>

为什么会出现错误?

更新 : XEP-0065以下说。 尽管这个错误看起来矿有一点不同,它是相关的? 如果是这样,是什么问题?

如果代理是无法充当流主机,代理必须返回一个错误给请求者,这应该是<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> 

更新 :在我期待到JID资源的XML的各种发送和检索位包含或排除是否是问题的时刻。 或替代,我甚至不具有在下面的XML是一种“自”。 该文档意味着我需要这个。 这是问题? 我没有看到一个电流方式的代码,使一个“从” ...

<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/12 11:00:为响应马特·J的回应,我张贴更多的XML。 我不知道马特要求什么是发送和检索,但为了以防万一,在这里它是完整的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>

这给没有反应,但看起来确定我的时候我比较的例子17 XEP-0065 。 但是,如果不包括资源的JID传入TurnSocket.m(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>

在我原来的问题上面的XML返回! (与503错误代码)。 此外,我注意到,这个XML包含“流主机”,但在这个阶段,它实际上应该包含“流主机使用的”? 为什么会出现错误? 应该或不应该包括我在“到”资源?

次要更新2012/4/19 15:07:我已经加入xmpp.proxy.transfer.required上的Openfire为假。 这是由于这些讨论: 这里和这里 。 我没有设置此服务器(我的同事所做的那样),我不明白是什么意思,但它似乎并没有取得我的问题有什么区别。

更新20/04/2012 10:00:我的503错误,我认为是正确的那里,当我不包括资源(根据此 )。 即使是这样的话,虽然,我不能确定,为什么我得到了全JID没有反应。

Answer 1:

503错误是由于这样的事实,我没有提供完整的JID。 例如,我提供friendsUsername @域名,而不是friendsUsername @域名/资源。

但是,我还没有成功建立连接,并打开了一个新的问题, 在这里



文章来源: OpenFire/XMPP 503 service-unavailable error (XEP-0065 using iOS XMPPFramework)