【问题标题】:OpenFire/XMPP 503 service-unavailable error (XEP-0065 using iOS XMPPFramework)OpenFire/XMPP 503 服务不可用错误(XEP-0065 使用 iOS XMPPFramework)
【发布时间】:2012-04-29 15:36:14
【问题描述】:

问题:我正在尝试使用 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>

为什么会出错?

更新XEP-0065 说如下。即使这个错误看起来与我的有点不同,它是否相关?如果有,有什么问题?

如果代理无法充当 StreamHost,则代理必须返回 请求者的错误,应该是&lt;not-allowed/&gt;

<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 中都没有“发件人”。文档暗示我需要这个。这是问题吗?我在代码中没有看到当前的方式来制作“来自”...

<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:为了响应 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 的 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>

并且返回了我上面原始问题中的 XML! (带有 503 错误代码)。此外,我注意到这个 xml 包含“streamhost”,但在这个阶段它实际上应该包含“streamhost-used”吗?为什么会出现错误?我应该或不应该在“to”中包含资源吗?

次要更新 19/04/2012 15:07:我在 OpenFire 上将 xmpp.proxy.transfer.required 添加为 false。这是由于这些讨论:herehere。我没有设置这个服务器(我的同事做了),我不明白这意味着什么,但它似乎对我的问题没有任何影响。

更新 20/04/2012 10:00:当我不包含资源时,我认为我的 503 错误是正确的(根据 this)。即使是这样,我也不确定为什么我没有收到完整 jID 的响应。

【问题讨论】:

  • 要回答您的问题的一部分,客户端从不发送“来自” - 它是由服务器在从客户端接收到节时添加到客户端的完整 JID(即包括资源)。
  • 我认为,如果您可以在尝试启动传输时获得更完整的 XML 日志来记录发送/接收的内容,那将有所帮助。看起来您可能正在向应该转到代理的收件人发送一个节。
  • 感谢您的回复,马特!我有信心现在我们可以解决这个问题。我将开始整理一个完整的 XML 日志。但是,我不确定当我将 JID 传递给 TurnSocket.m 时,它是否应该有资源?例如,friendsUsername@domain 或 friendsUsername@domain/resource。
  • 嗨,马特。请注意,我已经回答了我最初的问题,但为了清楚起见,我已经开始了一个新问题,专注于当前导致我出现问题的部分。如果你想看看,就在这里……stackoverflow.com/questions/10297009/…

标签: proxy xmpp openfire socks xmppframework


【解决方案1】:

503 错误是因为我没有提供完整的 JID。例如,我提供的是friendsUsername@domain,而不是friendsUsername@domain/resource。

但是我还是没有连接成功,又开了一个新问题here

【讨论】:

    猜你喜欢
    • 2012-05-05
    • 2012-09-02
    • 2012-08-22
    • 2012-07-17
    • 2017-03-13
    • 2015-01-14
    • 2012-02-16
    • 2014-12-02
    相关资源
    最近更新 更多