<!-- 一、当一个初始化实体用TLS保护一个和接收实体之间的流,其步骤如下: --> <!-- 1. 初始化实体打开一个TCP连接,发送一个打开的XML流头信息(其'version'属性设置为"1.0")给接收实体以初始化一个流。 --> <?xml version="1.0"?><stream:stream xmlns:stream="http://etherx.jabber.org/streams" version="1.0" xmlns="jabber:client" to="192.168.3.10" xml:lang="en" xmlns:xml="http://www.w3.org/XML/1998/namespace"> <!-- 2. 接收实体打开一个TCP连接,发送一个XML流头信息(其'version'属性设置为"1.0")给初始化实体作为应答。 --> <?xml version='1.0'?><stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' from='192.168.3.10' id='46ba179c-f82d-496e-a7e5-10f71181db2f' version='1.0' xml:lang='en'> <!-- 3. 接收实体向初始化实体提议STARTTLS范围(包括验证机制和任何其他流特性),如果TLS对于和接收实体交互是必需的,它应该(SHOULD)在<starttls/>元素中包含子元素<required/>. --> <stream:features> <ver xmlns="urn:xmpp:features:rosterver"/> <starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls"/> <mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl"> <mechanism>PLAIN</mechanism> <mechanism>ANONYMOUS</mechanism> </mechanisms> <register xmlns="http://jabber.org/features/iq-register"/> <compression xmlns="http://jabber.org/features/compress"> <method>zlib</method> </compression> <auth xmlns="http://jabber.org/features/iq-auth"/> </stream:features> <!-- 4. 初始化实体发出STARTTLS命令(例如, 一个符合'urn:ietf:params:xml:ns:xmpp-tls'名字空间的 <starttls/> 元素) 以通知接收实体它希望开始一个TLS握手来保护流。 --> <starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls"/> <!-- 5. 接收实体必须(MUST)以'urn:ietf:params:xml:ns:xmpp-tls'名字空间中的<proceed/>元素或<failure/>元素应答。如果失败,接收实体必须(MUST)终止XML流和相应的TCP连接。如果继续进行,接收实体必须(MUST)尝试通过TCP连接完成TLS握手并且在TLS握手完成之前不能(MUST NOT)发送任何其他XML数据。服务器通知客户端可以继续进行: --> <proceed xmlns="urn:ietf:params:xml:ns:xmpp-tls"/> <!-- 步骤 5 (或者): 服务器通知客户端 TLS 握手失败并关闭流和TCP连接: --> <failure xmlns='urn:ietf:params:xml:ns:xmpp-tls'/> </stream:stream> <!-- 6. 初始化实体和接收实体尝试完成TLS握手。(要符合[TLS]规范) --> <!-- 7. 如果 TLS 握手不成功, 接收实体必须(MUST)终止 TCP 连接. 如果 TLS 握手成功, 初始化实体必须(MUST)发送给接收实体一个打开的XML流头信息来初始化一个新的流(先发送一个关闭标签</stream>是不必要的,因为接收实体和初始化实体必须(MUST)确保原来的流在TLS握手成功之后被关闭) 。 --> <!-- 二、如果 TLS 握手成功,客户端继续 SASL 握手 -->
- 浏览: 120043 次
- 性别:
- 来自: 湛江
文章分类
最新评论
-
tianzhijie11:
真的太感谢了,我只是粗略的看了一下代码,写的真好,多了一套工具 ...
springmvc +mybatis 代码生成器 -
00zxcv963:
支持一下。
springmvc +mybatis 代码生成器 -
a942010:
顶,省去很多麻烦,程序员都是懒的~~
springmvc +mybatis 代码生成器 -
yangsong158:
拎图网,宸峯科技实业有限公司旗下产品。2014年5月成立。年轻 ...
springmvc +mybatis 代码生成器 -
iqeq00:
支持,加油....
springmvc +mybatis 代码生成器
<!-- 1.打开的XML流头 --> <?xml version="1.0"?> <stream:stream xmlns:stream="http://etherx.jabber.org/streams" version="1.0" xmlns="jabber:client" to="192.168.3.10" xml:lang="en" xmlns:xml="http://www.w3.org/XML/1998/namespace"> <!-- 2. 在从初始化实体收到新的流头信息之后,服务器发送一个流头信息应答客户端 --> <?xml version='1.0'?><stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' from='192.168.3.10' id='46ba179c-f82d-496e-a7e5-10f71181db2f' version='1.0' xml:lang='en'> <!-- 2.1接收实体必须(MUST)发送一个新的XML流头信息给初始化实体作为应答,其中应包含可用的特性但不包含STATRTTLS特性。 --> <stream:features> <ver xmlns="urn:xmpp:features:rosterver"/> <mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl"> <mechanism>PLAIN</mechanism> <mechanism>ANONYMOUS</mechanism> </mechanisms> <register xmlns="http://jabber.org/features/iq-register"/> <compression xmlns="http://jabber.org/features/compress"> <method>zlib</method> </compression> <auth xmlns="http://jabber.org/features/iq-auth"/> </stream:features> <!-- 3.初始化实体发送一个符合'urn:ietf:params:xml:ns:xmpp-sasl'名字空间的<auth/>元素(其中包含了适当的'mechanism'属性值)给接收实体,以选择一个机制。 --> <auth xmlns="urn:ietf:params:xml:ns:xmpp-sasl" mechanism="PLAIN">ADEyMwAxMjM0NTY=</auth> <!-- 4. 如果必要,接收实体向初始化实体发送一个符合 'urn:ietf:params:xml:ns:xmpp-sasl'名字空间的<challenge/>元素来发出挑战;这个元素可以(MAY)包含XML字符数据(必须按照初始化实体选择的SASL机制进行一致性运算)。 或: --> <challenge xmlns='urn:ietf:params:xml:ns:xmpp-sasl'> cmVhbG09InNvbWVyZWFsbSIsbm9uY2U9Ik9BNk1HOXRFUUdtMmhoIixxb3A9ImF1dGgi LGNoYXJzZXQ9dXRmLTgsYWxnb3JpdGhtPW1kNS1zZXNzCg== </challenge> <!-- 步骤 4 (替代): 服务器返回一个错误给客户端: --> <failure xmlns='urn:ietf:params:xml:ns:xmpp-sasl'><incorrect-encoding/></failure></stream:stream> <!-- 5. 初始化实体向接收实体发送符合'urn:ietf:params:xml:ns:xmpp-sasl'名字空间的<response/>元素作为应答;这个元素可以(MAY)包含XML字符数据(必须按照初始化实体选择的SASL机制进行一致性运算)。 客户端发送一个[BASE64]编码的回应这个挑战 --> <response xmlns='urn:ietf:params:xml:ns:xmpp-sasl'> dXNlcm5hbWU9InNvbWVub2RlIixyZWFsbT0ic29tZXJlYWxtIixub25jZT0i T0E2TUc5dEVRR20yaGgiLGNub25jZT0iT0E2TUhYaDZWcVRyUmsiLG5jPTAw MDAwMDAxLHFvcD1hdXRoLGRpZ2VzdC11cmk9InhtcHAvZXhhbXBsZS5jb20i LHJlc3BvbnNlPWQzODhkYWQ5MGQ0YmJkNzYwYTE1MjMyMWYyMTQzYWY3LGNo YXJzZXQ9dXRmLTgK </response> <!-- 6. 如果必要,接收实体发送更多的挑战给初始化实体,初始化实体发送更多的回应。 --> <!-- ()这一系列的 挑战/应答 组,持续进行直到发生以下三件事中的一件为止: --> <!-- 1. 初始化实体向接收实体发送符合'urn:ietf:params:xml:ns:xmpp-sasl'名字空间的<abort/>元素以中止握手。在接收到<abort/> 元素之后,接收实体应该(SHOULD)允许一个可配置的但是合理的重试次数(至少2次),然后它必须(MUST)终止TCP连接;这使得初始化实体(如一个最终用户客户端)能够容忍可能不正确的credentials(如密码输入错误)而不用强制重新连接。 --> 2. 接收实体向初始化实体发送符合'urn:ietf:params:xml:ns:xmpp-sasl'名字空间的<failure/>元素以报告握手失败(详细的失败原因应该在<failure/>的一个适当的子元素中沟通,在第六章第四节中的SASL Errors中定义)。如果失败的情况发生了,接收实体应该(SHOULD)允 许一个可配置的但是合理的重试次数(至少2次), 然后它必须(MUST)终止TCP连接;这使得初始化实体(如一个最终用户客户端)能够容忍可能不正确的credentials(如密码输入错误)而不用强制重新连接。 --> <!-- 3. 接收实体向初始化实体发送符合'urn:ietf:params:xml:ns:xmpp-sasl'名字空间的<success/>元素以报告握手成功;如果所选择的SASL机制要求,这个元素可以(MAY)包含XML字符数据(见SASL术语,“成功的额外数据”)。接收到<success/> 元素之后,初始化实体必须(MUST)发送一个打开的XML流头信息给接收实体以发起一个新的的流(不需要先发送一个 </stream>标签,因为在发送和接收到<success/>元素之后,接收实体和初始化实体必须确认原来的流被关闭了)。从初始化实体接收到新的流头信息之后,接收实体必须(MUST)发送一个新的流头信息给初始化实体作为回应,附上任何可用的特性(但不包括 STARTTLS 和 SASL 特性)或一个空的 <features/> 元素(这表示没有更多的特性可用);任何没有在本文定义的附加特性必须(MUST)在XMPP的相关扩展中定义。 --> <!-- 例如: 7.如果成功,接收实体向初始化实体发送符合'urn:ietf:params:xml:ns:xmpp-sasl'名字空间的<success/>元素以报告握手成功; --> <success xmlns="urn:ietf:params:xml:ns:xmpp-sasl"/> <!-- 步骤 7 (或者): 服务器通知客户端验证失败: --> <failure xmlns='urn:ietf:params:xml:ns:xmpp-sasl'><temporary-auth-failure/></failure></stream:stream> <!-- 三、sasl认证成功后 1.客户端发起一个新的流给服务器: --> <?xml version="1.0"?> <stream:stream xmlns:stream="http://etherx.jabber.org/streams" version="1.0" xmlns="jabber:client" to="192.168.3.10" xml:lang="en" xmlns:xml="http://www.w3.org/XML/1998/namespace"> <!-- 2.客户端发起一个新的流给服务器: --> <?xml version='1.0'?><stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' from='192.168.3.10' id='46ba179c-f82d-496e-a7e5-10f71181db2f' version='1.0' xml:lang='en'> <!-- 2.1并附上任何可用的特性(或空的features元素): 接收到一个成功的SASL握手之后,客户端必须(MUST)发送一个新的流头信息给服务器,服务器必须(MUST)返回一个包含可用的流特性列表的头信息。特别是,在成功的SASL握手之后如果服务器需要客户端绑定一个资源,它必须(MUST) 在握手成功之后(而不是之前)发送给客户端的应答流特性中包含一个空的符合'urn:ietf:params:xml:ns:xmpp-bind'名字空间的<bind/>元素。: --> <stream:features> <ver xmlns="urn:xmpp:features:rosterver"/> <session xmlns="urn:ietf:params:xml:ns:xmpp-session"/> <register xmlns="http://jabber.org/features/iq-register"/> <compression xmlns="http://jabber.org/features/compress"> <method>zlib</method> </compression> <bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"/> </stream:features> <!-- 3.客户端请求服务器绑定资源: 收到要求资源绑定的通知后,客户端必须(MUST)通过发送一个符合 'urn:ietf:params:xml:ns:xmpp-bind'名字空间的“set”类型的IQ节给服务器来绑定一个资源到流中。 --> <!-- 如果客户端端希望允许服务器给自己生成一个资源ID,它可以发送一个包含空的<bind/>元素的“set”类型的IQ节。: -->
<iq type="set" id="bind_1"> <bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"/> </iq> <!-- 3.(代替)如果客户端希望指定资源ID,它发送一个包含期望资源ID的“set”类型的 IQ节,把资源ID作为<bind/>元素下的<resource/>子元素的XML字符数据: --> <iq type="set" id="bind_1"> <bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"> <resource>DELL-PC</resource> </bind> </iq> <!-- 4.一旦服务器为客户端生成了一个资源ID或接受了客户端自己提供的资源ID,它必须(MUST)返回一个“result”类型的 IQ 节给客户端,这个节必须包含一个指明全JID的<jid/>子元素表示服务器决定连接的资源: 服务器通知客户端资源绑定成功: --> <iq xmlns="jabber:client" type="result" id="bind_1" to="123@192.168.3.10/DELL-PC"> <bind xmlns="urn:ietf:params:xml:ns:xmpp-bind"> <jid>123@192.168.3.10/DELL-PC</jid> </bind> </iq> <iq type="set" id="aadaa"> <session xmlns="urn:ietf:params:xml:ns:xmpp-session"/> </iq> <iq type="result" id="aadaa" to="123@192.168.3.10/DELL-PC"/> <iq type="get" id="aadba"> <query xmlns="jabber:iq:roster"/> </iq> <iq type="result" id="aadba" to="123@192.168.3.10/DELL-PC"> <query xmlns="jabber:iq:roster"> <item subscription="both" name="789456" jid="789456@192.168.3.10"/> <item subscription="both" name="qaz" jid="qaz@192.168.3.10"/> </query> </iq> <presence> <priority>5</priority> <c xmlns="http://jabber.org/protocol/caps" node="http://psi-im.org/caps" ver="caps-b75d8d2b25" ext="ca cs ep-notify-2 html"/> </presence> <iq type="get" id="aadda"> <query xmlns="jabber:iq:private"> <storage xmlns="storage:bookmarks"/> </query> </iq> <iq type="get" to="123@192.168.3.10" id="aadea"> <vCard xmlns="vcard-temp"/> </iq> <iq type="get" to="192.168.3.10" id="aadfa"> <query xmlns="http://jabber.org/protocol/disco#info"/> </iq> <presence from="123@192.168.3.10/DELL-PC" to="123@192.168.3.10"> <priority>5</priority> <c xmlns="http://jabber.org/protocol/caps" node="http://psi-im.org/caps" ext="ca cs ep-notify-2 html" ver="caps-b75d8d2b25"/> </presence> <iq type="result" id="aadda" to="123@192.168.3.10/DELL-PC"> <query xmlns="jabber:iq:private"> <storage xmlns="storage:bookmarks"/> </query> </iq> <iq from="123@192.168.3.10" type="result" id="aadea" to="123@192.168.3.10/DELL-PC"> <vCard xmlns="vcard-temp"/> </iq> <iq type="get" to="123@192.168.3.10/DELL-PC" id="aae0a"> <query xmlns="jabber:iq:version"/> </iq> <presence from="789456@192.168.3.10/DELL-PC" to="123@192.168.3.10"> <priority>5</priority> <c xmlns="http://jabber.org/protocol/caps" node="http://psi-im.org/caps" ext="ca cs ep-notify-2 html" ver="caps-b75d8d2b25"/> </presence> <iq from="123@192.168.3.10/DELL-PC" type="result" id="aae0a" to="123@192.168.3.10/DELL-PC"> <query xmlns="jabber:iq:version"> <name>Tigase</name> <version>0.0.0-0</version> <os>Windows 7-amd64-6.1, Java HotSpot(TM) 64-Bit Server VM-24.60-b09-Oracle Corporation</os> </query> </iq> <iq from="192.168.3.10" type="result" id="aadfa" to="123@192.168.3.10/DELL-PC"> <query xmlns="http://jabber.org/protocol/disco#info"> <identity category="component" type="im" name="Tigase ver. 0.0.0-0"/> <identity category="server" type="im" name="Tigase ver. 0.0.0-0"/> <feature var="http://jabber.org/protocol/commands"/> <feature var="http://jabber.org/protocol/stats"/> <feature var="http://jabber.org/protocol/commands"/> <feature var="jabber:iq:version"/> <feature var="jabber:iq:roster"/> <feature var="jabber:iq:roster-dynamic"/> <feature var="vcard-temp"/> <feature var="urn:ietf:params:xml:ns:xmpp-sasl"/> <feature var="urn:xmpp:ping"/> <feature var="urn:ietf:params:xml:ns:xmpp-session"/> <feature var="http://jabber.org/protocol/amp"/> <feature var="msgoffline"/> <feature var="http://jabber.org/protocol/disco#info"/> <feature var="http://jabber.org/protocol/disco#items"/> <feature var="jabber:iq:privacy"/> <feature var="urn:ietf:params:xml:ns:xmpp-bind"/> <feature var="urn:xmpp:carbons:2"/> <feature var="jabber:iq:private"/> <feature var="jabber:iq:auth"/> </query> </iq>
发表评论
-
tigase源码分析7:用户连接登录流程
2015-04-30 16:13 4310//在看本节之前一定要先了解下xmpp协议,建议仔细看下 ... -
tigase源码分析5:SessionManager
2015-04-30 16:12 2816这节主要是分析数据 ... -
tigase源码分析4:packet处理
2015-01-14 10:17 1904这节主要讲数据包packet 的流转过程,如图大概 ... -
tigase源码分析3:SocketThread
2015-01-14 10:37 1568SocketThread 专用于处理客户端SOCKE ... -
tigase源码分析2:ConnectionOpenThread 处理服务端socket的线程
2014-12-31 11:22 3089一、 ConnectionOp ... -
tigase源码分析1:启动
2014-12-30 12:20 5538喜欢研究IM技术的同学们,欢迎加入群 3 ...
相关推荐
Tigase XMPP 服务器 Docker 映像 安装了 Tigase XMPP 服务器 (5.2.3) 的 Docker 映像用于评估目的。 请勿在生产环境中使用。 为帐户注册和配置存储设置了非持久性 Derby 数据库。 在此设置中创建了一个不存在的...
Tigase Swift XMPP客户端库这是什么Tigase Swift XMPP客户端库是用编程语言编写的客户端库。 它提供了XMPP标准核心的实现并处理XML。 此外,它还提供了对许多流行扩展(XEP)的支持。 该存储库包含该库的源文件。...
该资源是整合了tigase的java服务端源代码,环境为:idea + gradle + postgresql 注意,这部分项目只包括java源代码,而数据库备份将在下一个资源打包上传,有疑问请阅读相关博文: ...
tigase相关jar包
Tigase是一个开源项目,使用Java语言编写,遵循Jabber(即XMPP)协议标准,为用户提供了一个高性能且可扩展的消息传递和即时通讯(IM)平台。Tigase的核心优势在于其能够支持大量的并发用户连接,并通过集群技术实现...
Tigase XMPP服务器是高度优化,高度模块化且非常灵活的用Java编写的XMPP / Jabber服务器。 该存储库包含Tigase XMPP服务器主要部分的源代码。 该项目自2004年成立以来,我们最近已将其移至GitHub。 与XMPP相关的...
Tigase是一个实现了XMPP协议的服务器,可以用来构建自己的即时通信服务。XMPP(Extensible Messaging and Presence Protocol,前称Jabber)是一种以XML为基础的开放式实时通信协议,是经由互联网工程工作小组(IETF...
1. **XML流处理**:了解XMPP协议的XML流结构,这是编写插件的基础。 2. **Tigase API**:学习Tigase提供的API,如SessionManager、PacketFilter等。 3. **插件开发**:编写Java代码实现特定功能,如自定义业务逻辑、...
1. **XMPP协议**:XMPP是一种基于XML的即时通讯协议,广泛应用于各种实时通信系统。Tigase服务器就是对这一协议的实现,它允许用户通过XMPP客户端进行交互。 2. **Java编程**:Tigase服务器的核心是用Java编写的,...
Tigase 完全实现了 XMPP 协议,除了全面实施的两个核心协议,它支持大多数的你可能永远都需要的扩展协议。开源的特性使得用户可以自定义和修改代码,提高了软件的可靠性和安全性。同时,Tigase 的设计也充分考虑到...
解决这些问题需要开发者熟悉Maven构建工具的使用,了解Eclipse集成开发环境的配置技巧,以及对Tigase以及XMPP协议有一定的了解。因此,源码部署不仅是一种技术活动,更是一种技术能力和知识水平的体现。通过源码部署...
Tigase是一款开源、跨平台的XMPP(Extensible Messaging and Presence Protocol)服务器,支持多种协议,如Jabber、GTalk、Facebook Messenger等。Web Chat则是Tigase生态系统中的一个组件,它允许用户通过浏览器...
clj-tigase是一个简单的库,用于处理Clojure的Tigase XMPP服务器。 使用 与雷宁根: [clj-tigase "0.1.0"] 使用Maven: <groupId>clj-tigase <artifactId>clj-tigase <version>0.1.0 </dependency>
* urn:ietf:params:xml:ns:xmpp-sessions:session绑定 * jabber:iq:roster:联系人名单管理 * presence-state:xmpp顶级元素,上线广播 * jabber:iq:privacy:隐身协议 * jabber:iq:version:客户端版本 * ...
2. Git:用于从官方仓库克隆Tigase源代码,虽然我们这里提到的是快速部署,但了解如何获取最新源码总是有好处的。 接下来,我们将详细介绍快速配置和部署Tigase的步骤: 1. **下载Tigase**:您可以从Tigase官方...
Tigase 5.2是该服务器的一个版本,提供了强大的可扩展性和稳定性,支持多种协议如XMPP、Jabber等。这个压缩包包含的是Tigase 5.2的完整源代码,以及与之配套的MySQL数据库,使得用户能够快速地在Eclipse开发环境中...
Tigase是一款开源的XMPP服务器,用于实现即时通讯和在线状态服务。它采用Java语言编写,具有跨平台性,并且支持多种扩展协议,如多用户聊天(MUC)、消息存档(Message Archiving)和发布订阅(PubSub)等。在你提供...
Tigase服务器是一款开源的XMPP(Extensible Messaging and Presence Protocol)服务器,它支持即时通讯、在线状态服务、多用户聊天室以及各种扩展协议。在IT行业中,掌握Tigase服务器的配置和使用对于开发实时通信...
全面:tigase 完全实现了XMPP协议,除了全面实施的两个核心协议,它支持大多数的你可能永远都需要的扩展协议。 开源:Tigase是开源的,如果你有有那能力,你可以定制自己的XMPPServer,虽然经过了很多次此时,但是...
9. **客户端集成**:为了让用户能够使用Tigase,你需要选择或开发支持XMPP协议的客户端应用。常见的XMPP客户端有Pidgin、Gajim等。 Tigase服务器支持多种扩展,如群聊、多用户聊天室、文件传输、推送通知等,可以...