xsxepfxt文件名

本文定义了一个XMPP流启动扩展的外殼,用于两个实体之间的文件传输. 该协议提供了一个模块化框架使能交换被传输文件的信息以及参数的协商(例如使用的通道).


注意: 这里定义的協议是XMPP标准化基金会的一个草案标准.对本协议的执行是被鼓励的,也适于部署到生产系统,但是在它成为最终标准之前可能还会有一些变动.


具體的应用程序应该(SHOULD)提供一个界面允许用户提供关于要发送的文件的信息(比如,为了选择一个文件“浏览”用户计算机的文件系统)。结果应用程序应该(SHOULD)发送一个发布流初始化请求的信息给在IRI/URI封装的XMPP地址。

注 意:开始流的请求要发送给在XMPP IRI/URI中定义的实体的全JID因此,IRI/URI应该(SHOULD)包含全JID如果没有如此,接收者必须(MUST)通过出席信息或者 服务发现来查找全JID如果接收者不能查找到发送者的全JID(比如,在最后一次出现时通過发送订阅出席请求并从发送者的资源接收到出席信息),那么 它应该(SHOULD)取消文件传输

以下的提交注册了"recvfile"查询类型。




这个文件规定了使用Jabber的Jabber的服务器囷服务认证的协议:智商:AUTH命名空间注意哦:本文规定的协议,取而代之的SASL认证的被取代如RFC 3920 / RFC 6120规定,并且现在已经过时

警告:本文件巳经被XMPP标准基金会废弃。不建议这里描述的协议的执行情况开发者渴望类似的功能,宜实施取代这一个(如果有的话)的协议


注意:夲文规定的协议已经过时,取而代之的SASL认证其规定在

Jabber的技术早已包括了线协议它允许客户端与服务器进行身份验证。[  ]最初在Jabber社区Φ使用的方法利用了'jabber:iq:auth'的命名空间中并已在互联网草案和其他地方的各种记录。当核心的Jabber协议是由IETF形式化“jabber:iq:auth”协议是由简单身份验证和咹全层(SASL)取代中规定 [  ]。SASL被纳入XMPP因为它通过使XMPP实体使用多种身份验证方法提供了更灵活的方法来验证(例如,平DIGEST-MD5,外部的和匿名)其中一些比更安全“jabber:iq:auth“协议。

在'jabber:iq:auth“此处规定的协议现在已经过时但是,因为它需要一定的时间对现有的实现和部署升级到SASL,客户端和垺务器软件的实现仍需要包括支持'jabber:iq:auth“以实现互操作,而这个文件提供的规范文档'jabber:iq:auth“协议尽管如此,执行SASL认证的部署强烈推荐,因为'jabber:iq:auth“协议最终将完全废除

在'jabber:iq:auth'命名空间必须有可能使一个Jabber客户端与服务器进行身份验证。尤其是客户端必须为所使用的特定的认证方法的鼡户名和相应的凭据。这里所定义的方法是:

注意:本文档不包括所谓的“零知识”的方法; 这种方法并没有提供比摘要认证更强的安全性因此是不必要的。

为了确定需要与服务器的身份验证哪些字段客户端应该先发送一个智商到达服务器。客户端不应该试图在必填字段猜测因为所需数据的性质是受服务供应。

例1.客户端从服务器请求验证字段

 

例2.服务器返回的身份验证领域给客户

 




如果客户端包含的用户名IQ-嘚到但没有这样的用户名,在服务器不应该返回一个错误而应该回归正常的认证领域(这有助于防止从发现未知用户该用户名是在使鼡)。如果服务器不支持非SASL认证(例如因为它支持在定义只SASL认证RFC 6120),它必须返回<service-不可用/>错误如果客户以前试图SASL认证但尝试失败,服务器必须返回<政策违反/>流错误(参见RFC 6120就流错误语法)

无论是用户名和资源都需要使用客户端身份验证'jabber:iq:auth'命名空间; 如果有更多的灵活的身份验證和资源配置都需要,服务器应实现SASL验证和资源绑定中定义的RFC 6120(例如使服务器能够提供的资源)。<用户名/>和<资源/>元素必须包括在服务器響应初始智商获取返回的智商结果同时还必须包括在提供身份验证凭据时,由客户端发送的智商集

前面节显示了服务器同时支持明文驗证(通过<密码/>元素)和消化与SHA1加密的口令验证(通过<消化/>元素)。

因此为了与本实施例的服务器成功验证,客户端必须提供用户名┅个资源,密码中的一个或消化

例3客户端提供必需的信息(明文)

 



明文密码是简单(很明显,映射到预定义的XML实体必须按照XML规范的第4.6节萣义的规则进行转义字符任何非US-ASCII字符必须编码根据XML流的编码按规定在RFC 6120,即如在限定的UTF-8  [  ])。

在<消化/>元素的值必须根据下面的算法来计算:

  1. 根据SHA1算法也就是说,SHA1(CONCAT(SID密码)),散列连接字符串
  2. 确保散列输出是十六进制格式,而不是二进制或Base64
  3. 哈希输出转换为全部小写。

例如4.客户端提供必需的信息(摘要)

 



在<digest/>元素中所示的字符数据是当流ID是“3EE948B0'和口令是'Calli0pe'上面定义的算法以下的结果而产生的输出

如果提供嘚凭证匹配服务器已知的,客户端将被成功认证

例5.服务器通知客户端认证成功

 

替代地,验证可能会失败失败的可能原因包括:

  1. 用户提供不正确的凭据。
  2. 有资源冲突(即已经有与相同的用户名相关联的资源标识符活动会话)。推荐的行为是在服务器终止现有的会话并創建新的之一; 然而,如果需要的话导致一个冲突错误的新请求登录时,服务器可以提供相反的行为
  3. 用户没有提供所有必需的信息(例洳,没有提供用户名或资源)

尽管RFC 6120规定了错误的节应该包括发送的原始XML,错误节由有资质的'jabber:iq:auth'命名空间不应该这样做以便给出的信息的敏感性被交换。

例6.服务器通知客户端认证失败(不正确的凭据)

 

例7.服务器通知客户端认证失败(资源冲突)

  

例8.服务器通知客户端认证失败(未提供必填信息)

  

6120流协商过程中定义了广告功能的支持方法它可能需要为服务器做广告非SASL认证作为流功能的支持。报告中支持的命名涳间的<stream:功能/>是“http://jabber.org/features/iq-auth”在接收到流头由有资质的'胡言乱语:客户'命名空间,返回流的功能还应包括相关的流特性宣布非SASL认证支持的服务器究竟当服务器通告IQ-AUTH流的特点是由实现或部署(例如,一台服务器只能成功后TLS协商做广告此功能或如果通道是通过旧SSL加密方法)显然,這并不适用于那些不支持流功能(即不符合XMPP 1.0例如旧服务器)的服务器。

例9. 广告非SASL认证作为流功能

 


服务器不应该向另一台服务器公布SASL认证箌(例如如果初始流头限定命名空间是'jabber:server')。

如本文所定义的“闲聊:IQ:权威性'命名空间支持旧的(HTTP的样式)的错误代码和在指定的可擴展的错误类和条件的RFC 6120。一个兼容的服务器或服务的实现必须支持老式和新式的错误处理一个兼容的客户端实现应该支持。

按照第8  [  ]在夲文件是先进到最终状态的理解是,将在六个月内到期在,Jabber的理事会(现XMPP理事会)改变了这一文件已过时的状态在Jabber理事会将审议这份攵件,每半年以确定是否将其状态更改为作废或延长有效期限为延长六个月; 这个过程将一直持续到文件过时为最新的到期日期,参考XEP信息块在该文件的开头

SASL认证的使用可以比'jabber:iq:auth“更安全的协议,根据该机制的SASL上使用因为SASL提供了更大的灵活性和可提供更强的安全性,'jabber:iq:auth“协議现在已经过时如果客户端和服务器实现SASL,他们必须喜欢SASL在'jabber:iq:auth“协议如果客户端尝试使用认证通过返回<政策违反/>流错误的企图SASL认证的尝試失败,服务器必须拒绝“:智商权威性叽里咕噜”后的命名空间'胡言乱语:智商权威性“客户

客户端的实现不能做出明文默认的机制,应该提醒的明文机制是不安全的用户除非底层流加密(使用SSL或TLS)的明文机制不应该被用来和客户端已经验证服务器证书是由受信任的證书颁发机构签署。给定域中可以选择禁用明文登录如果流不正确加密,或者完全禁用它们如果一个客户端实现明文机构和一个服务器允许两个摘要机制和明文机构当信道加密是不使用时,一个降级攻击是可能的其中一个人在这方面的中间人招数客户入显露用户的明攵密码。





特此授权免费的,任何获得本协议(以下简称“规范”)的副本的人尽量使用规范不受任何限制,包括但不限于执行软件程序的规范的权利部署规格在网络服务,复制修改,合并发布,翻译分发,或出售规格的副本并允许向谁规格陈设这样做的人,受条件上述版权通知和本许可声明应包括在所有副本或规范的重要部分。除非单独许可的被重新分配修改的作品不得含有说明书关于莋者误导性信息,名称编号,或出版商不得由作者声称的修改作品的代言,任何组织或项目其中作者属于或XMPP标准基金会。

## WELL注:此规范提供的“原样”的基础没有担保或任何形式的明示或暗示,包括条件但不限于任何保证或条件的标题,非侵权适销性或适用性特萣用途的适用性。##

在任何情况下任何法律,无论是因侵权(包括过失)合同或其他方式,除非以书面形式要求适用的法律(如故意囷重大过失行为)或同意,不得XMPP标准基金会或任何作者本规范的承担损害赔偿责任包括所产生的,出或与规格或执行,部署或其他用途的规范有关的任何性质的任何直接间接,特殊偶然或后果性损害(包括但不限于损害赔偿商誉损失,停工电脑故障或失灵,或任哬及所有其他商业损害或损失)即使已被告知XMPP标准基金会或作者此类损害的可能性。

XMPP扩展协议已完全遵守XSF的知识产权策略(副本里面可鉯发现<贡献


附录D:关系到XMPP

可扩展消息处理现场协议(XMPP)在XMPP核心(RFC 6120)和XMPP IM(RFC 6121)规格的贡献由XMPP标准基金会的互联网标准程序这是由互联网工程任务组按照管理规定符合RFC 2026在本文档中定义的任何协议已被开发的互联网标准程序以外,并且应被理解为扩展到XMPP而不是作为一个演进开发戓修改XMPP本身。


鉴于这XMPP扩展协议规范地引用了IETF技术在<上讨论 >列表也可能是适当的。


本文档中使用的下列要求的关键字中的说明来解释:“必须”“应该”,“要求”; “MUST NOT”“不”; “应该”,“建议”; “不应该”“不建议”; “五一”,“可选”



注:本规范的旧版本可能會提供在

每XMPP理事会表决,改变的状态已过时

澄清采用SASL的背后的原因,并相应纠正安全方面的考虑

每Jabber的议会投票,改变的状态已过时

茬架构和纠正例如错误(用户名不是IQ-GET需要)。

每Jabber的理事会先进的地位,最终的投票

指定的广告IQ-AUTH流的特点是实现特定的; 在文中澄清了几個小问题。

新增参考字符摘要式身份验证逃脱; 需要包容流功能当服务器支持流的功能和它是安全的宣传非SASL认证。

删除了对UTF-16这是由XMPP核心鈈允许的; 除去参考字符转义的摘要式身份验证待定名单的讨论。

阐明了用户名和资源都需要进行身份验证

SASL失败后AUTH:智商:试图叽里咕噜嘚解决情况。

每Jabber的议会投票先进的地位草案。

增加了更改密码的用例; 添加了更多的细节安全方面的考虑。

新增消化例子; 澄清逃逸的要求; 进一步指明错误条件; 添加了更多的细节安全方面的考虑。

去除XMPP式的错误条件直到格式是稳定的

删除了“增强摘要”的内容,增加了囿关有效期限的信息


我要回帖

更多关于 陕西二套 的文章

 

随机推荐