收藏 分享(赏)

openfire管理目标消息流程解析及其openfire详细信息.doc

上传人:小屁孩 文档编号:8853691 上传时间:2019-07-14 格式:DOC 页数:87 大小:1,004.50KB
下载 相关 举报
openfire管理目标消息流程解析及其openfire详细信息.doc_第1页
第1页 / 共87页
openfire管理目标消息流程解析及其openfire详细信息.doc_第2页
第2页 / 共87页
openfire管理目标消息流程解析及其openfire详细信息.doc_第3页
第3页 / 共87页
openfire管理目标消息流程解析及其openfire详细信息.doc_第4页
第4页 / 共87页
openfire管理目标消息流程解析及其openfire详细信息.doc_第5页
第5页 / 共87页
点击查看更多>>
资源描述

1、#*XMPP 介绍Extensible Messaging and Presence Protocol,简单的来讲,它就是一个发送接收处理消息的协议,但是这个协议发送的消息,既不是二进制的东东也不是字符串,而是 XML。正是因为使用了 XML 作为消息传递的中介, Extensible 才谈的上,不是么? IMInstant Messenger,及时通信软件,就是大家使用的 QQ、MSN Messenger 和 Gtalk 等等。其中 Gtalk 就是基于 XMPP 协议的一个实现,其他的则不是。当前 IM 几乎作为每个上网者必然使用的工具,在国外的大型企业中有一些企业级的 IM 应用,但是其

2、商业价值还没完全发挥出来。设想既然 XMPP 协议是一个公开的协议,那么每个企业都可以利用它来开发适合本身企业工作,提高自身生产效率的 IM;甚至,你还可以在网络游戏中集成这种通信软件,不但让你可以边游戏边聊天,也可以开发出适合游戏本身的 IM 应用,比如说一些游戏关键场景提醒功能,团队语音交流等等都可以基于 IM 来实现。Spark Smack 和 Openfire开源界总是有许多有趣的东东,这三个合起来就是一个完整的 XMPP IM 实现。包括服务器端Openfire ,客户端 Spark,XMPP 传输协议的实现Smack(记住,XMPP 是一个协议,协议是需要实现的, Smack 起到

3、的就是这样的一个作用) 。三者都是基于 Java 语言的实现。Spark 提供了客户端一个基本的实现,并提出了一个很好的插件架构,这对于开发者来说不能不说是一个福音。我强烈建议基于插件方式来实现你新增加的功能,而不是去改它的源代码,这样有利于你项目架构,把原始项目的影响降到最低。Openfire 是基于 XMPP 协议的 IM 的服务器端的一个实现,虽然当两个用户连接后,可以通过点对点的方式来发送消息,但是用户还是需要连接到服务器来获取一些连接信息和通信信息的,所以服务器端是必须要实现的。Openfire 也提供了一些基本功能,但真的很基本的!庆幸的是,它也提供插件的扩展,像 Spark 一样

4、,同样强烈建议使用插件扩展的方式来增加新的功能,而不是修改人家的源代码。Smack 是一个 XMPP 协议的 Java 实现,提供一套可扩展的 API,不过有些时候,你还是不得不使用自己定制发送的 XML 文件内容的方式来实现自己的功能下图展示了三者之间的关系:#*从图上可以了解到,client 端和 server 端都可以通过插件的方式来进行扩展,smack 是二者传递数据的媒介。Apache MINAOpenfire 的通信处理基于 Apache MINA 框架实现。Apache MINA 是一个网络应用程序框架,用来帮助用户简单地开发高性能和高可靠性的网络应用程序。它提供了一个通过Jav

5、a NIO 在不同的传输例如 TCP/IP 和 UDP/IP 上抽象的事件驱动的异步 API。 Apache MINA 也称为: NIO 框架库 客户端服务器框架库 一个网络套接字库 MINA 虽然简单但是仍然提供了全功能的网络应用程序框架: 为不同的传输类型提供了统一的 API: 通过 Java NIO 提供 TCP/IP 和 UDP/IP 支持 通过 RXTX 提供串口通讯 (RS232) In-VM 管道通讯 你能实现你自己的 API! 过滤器作为一个扩展特性; 类似 Servlet 过滤器 低级和高级的 API: 低级: 使用字节缓存 (ByteBuffers) 高级: 使用用户定义的

6、消息对象 (objects)和编码(codecs) 高度定制化线程模型: 单线程 一个线程池 一个以上的线程池(也就是 SEDA) #* 使用 Java 5 SSL 引擎提供沙盒(Out-of-the-box) SSL TLS StartTLS 支持 超载保护和传输流量控制 利用模拟对象进行单元测试 JMX 管理能力 通过 StreamIoHandler 提供基于流的 I/O 支持 和知名的容器(例如 PicoContainer、Spring)集成 从 Netty 平滑的迁移到 MINA, Netty 是 MINA 的前辈。命名规则Openfire 中常见的类名后缀命名包括Starter、Pl

7、ugin、Listener、Dispatcher、Handler、Manager、Provider,通常情况下,这些命名类包括如下意义:XXStarter 系统启动类,如 org.jivesoftware.openfire.starter.ServerStarter,调用其 start()方法可启动系统应用。XXListener业务的最终处理类。XXDispatcher调度类,其中有很多关键方法,如 addListener(),以组合的方式,为类内定义的静态 Set实例添加 XXListener 对象。以便调用dispatchEvent(String property, EventType e

8、ventType, Map params)方法遍历处理 Set 集中的 XXListener 对象(通过调用XXListener 对象的各实际方法完成实际业务)。XXPlugin实现 Plugin 接口的插件类,需实现 initializePlugin(PluginManager manager, File pluginDirectory)方法和 destroyPlugin()方法。在其初始化方法中调用 Dispatcher 实现类的 addListener()方法如PropertyEventDispatcher.addListener(this)。#*XXProvider实现面向接口编程方式

9、的接口类,通过反射机制创建具体实现类的对象,反射类名配置在 ofproperty 表对应的记录 propvalue 属性中。若没有相关配置,则调用默认实现类,默认实现类类名命名规则为 DefaultXXProvider。XXHandler实际处理类,以 ConnectionHandler 为例,在org.jivesoftware.openfire.spi. ConnectionManagerImpl 类的startClientSSLListeners(String localIPAddress)方法中,有这样一段代码:sslSocketAcceptor.bind(new InetSocketA

10、ddress(bindInterface, port), new ClientConnectionHandler(serverName);其中bind方法的第二个参数是新创建的一个ClientConnectionHandler的实例,而它就是ConnectionHandler的一个子类。系统配置项Openfire 的系统配置项采用文件结合数据库表的方式配置,也有部分默认配置项通过 Java 硬编码方式配置(如 org.jivesoftware.openfire. ConnectionManager 接口类中定义的DEFAULT_PORT、DEFAULT_SSL_PORT、DEFAULT_COM

11、PONENT_PORT 等),Openfire中比较重要的配置位置包括:一、 src/conf 目录下的 openfire.xml 配置文件。该配置文件为系统核心配置文件。在第一次启动 Openfire 并通过管理控制台完成安装配置后会往该配置文件中填入相应的配置信息。二、 plugin.xml 配置文件。该配置文件为各插件包下的核心配置文件,由它确定插件核心处理类和相应页面插件的展现等。配置项及含义详见官方插件开发说明部分。三、 web.xml 和 web-custom.xml 配置文件。用于配置 servlet 和用户自定义 servlet(插件页面用,放在插件对应目录下)。四、 ofpr

12、operty 中的各条记录,该表中包括两个字段 name 和 propvalue,分别代表配置项名和配置项值。系统启动流程系统启动时调用 ServerStarter 类中的 start()方法,通过反射加载org.jivesoftware.openfire.XMPPServer 类文件,创建实例时调用其构造函数,#*在其构造函数中调用其 start()方法实际启动服务应用程序。Start()方法中首先调用 verifyDataSource()方法验证并确保数据库可以访问,然后会调用 loadModules();initModules();startModules();方法来对 Module 接

13、口的实现类的各子类进行操作,依次完成模块的加载、初始化和启动操作。loadModules()方法中会调用loadModule(String module)方法通过反射加载各模块类,参数字符串 module 为对应的模块核心处理类的类名,如 AdHocCommandHandler。现以 AdHocCommandHandler 为例对接下来的处理流程进行说明。通过 loadModule 创建 AdHocCommandHandler 类实例时调用其构造函数,在构造函数中初始化了其私有 AdHocCommandManager 对象。在initModules()时调用 AdHocCommandHandl

14、er 实例的 initialize(XMPPServer server)方法对其私有属性对象进行初始化。然后调用 start()方法,调用addDefaultCommands 方法添加命令并启动命令(通过调用startCommand(AdHocCommand command)方法实现)。网络处理消息监听服务SSL 等监听服务的调度在 ConnectionManagerImpl 类中实现。ConnectionManagerImpl.createClientSSLListeners()方法启动 SSL 监听消息封装信息处理采用 XML 节的方式传递信息,消息封装通常采用IQ、Message、Pre

15、sence。#*Openfire 消息包接受处理流程#*数据库处理Openfire 的数据库处理采用直接调用 JDBC 的方式。核心类为org.jivesoftware.database.DbConnectionManager。数据库的处理与业务处理耦合,没有划分出专门的业务逻辑层。ConnectionProvider此类为数据库提供者接口,如需连接 mysql、hsqldb 等数据库,需首先实现些接口,处理方式通常直接调用 XXManager 中的实例方法,XXManager 中又调用的是对应的接口 XXProvider 的方法,实际操作在该接口的实现类中实现。实现类是动态绑定的(默认的实现

16、类通常命名规则为 DefaultXXProvider),在运行时根据ofproperty 表中对应配置项值选择。下面以添加用户组为例进行说明。首先获得 GroupManager 的一个实例,在调用其构造函数时调用initProvider()方法,在该方法中获取数据库中配置项的值,若不为空则根据该值通过反射机制获取 GroupProvider 接口的实现类实例对象;若为空则以DefaultGroupProvider 作为 GroupProvider 接口的实现类并创建实例对象,然后调用 GroupProvider. createGroup(String name)方法完成业务操作。常用类org.

17、jivesoftware.database.DbConnectionManager连接管理类org.jivesoftware.util.JiveGlobals通常用于操作 ofproperty 表中记录openfire 数据结构数据库表以下是一个说明每个表格的 Openfire 数据库架构。黄色行表示主键。 ofGroup ofGroupProp #* ofGroupUser ofID ofOffline ofPresence ofPrivate ofUser ofUserProp ofUserFlag ofRoster ofRosterGroups ofPrivacyList ofVCard

18、 ofVersion ofProperty ofExtComponentConf ofRemoteServerConf ofSecurityAuditLog ofMucService ofMucServiceProp ofMucRoom ofMucRoomProp ofMucAffiliation ofMucMember ofMucConversationLog #* ofPubsubNode ofPubsubNodeJIDs ofPubsubNodeGroups ofPubsubAffiliation ofPubsubItem ofPubsubSubscription ofPubsubDef

19、aultConf ofGroup (用户组的数据)列名 类型 长度 描述groupName VARCHAR 50 组名称(主键)description VARCHAR 255 组描述ofGroupProp (名称值协会为一组)列名 类型 长度 描述groupName VARCHAR 50 组名称(主键)name VARCHAR 100 组属性名称(主键)propValue VARCHAR 4000 组属性值ofGroupUser (组成员)列名 类型 长度 描述groupName VARCHAR 50 组名称(主键)username VARCHAR 100 用户名(主键)administrat

20、or NUMBER n/a 是否为管理员(布尔)(主键)ofID (用于唯一 ID 序列生成)列名 类型 长度 描述idType NUMBER n/a 证件类型(例如,组,用户名册)(主键)id NUMBER n/a 下一个可用块编号的(用于数据库独立编号)ofOffline (离线邮件存储)列名 类型 长度 更改username VARCHAR 32 用户名(主键)messageID NUMBER n/a 存储信息的编号(主键)creationDate VARCHAR 15 日期信息存储messageSize NUMBER n/a 邮件的大小以字节为单位stanza TEXT n/a 消息文

21、本ofPresence (离线的存在)列名 类型 长度 更改username VARCHAR 64 用户名(主键)#*offlinePresence TEXT n/a 存在的信息设置为用户注销offlineDate CHAR 15 信息存储日期ofPrivate (私人数据存储)列名 类型 长度 描述username VARCHAR 32 用户名(主键)name VARCHAR 100 姓名私营项(主键)namespace VARCHAR 200 名字空间私营项(主键)privateData TEXT n/a 价值的私人数据ofUser (用户数据)列名 类型 长度 描述username VA

22、RCHAR 32 用户名(主键)plainPassword VARCHAR 32 纯文字密码数据encryptedPassword VARCHAR 255 加密的密码数据(默认)name VARCHAR 100 名字email VARCHAR 100 电邮地址creationDate VARCHAR 15 创建日期modificationDate VARCHAR 15 最后更新日期ofUserProp (名称值协会针对用户)列名 类型 长度 描述username VARCHAR 32 用户名(主键)name VARCHAR 100 用户属性名称(主键)propValue VARCHAR 400

23、0 用户属性值ofUserFlag (用户类型标识(如残疾人)列名 类型 长度 描述username VARCHAR 64 用户名(主键)name VARCHAR 100 用户属性名称(主键)startTime CHAR 15 国旗的时候,开始被有效(无效的现在 )endTime CHAR 15 当时国旗是结束有效(无效的永远 )ofRoster (好友列表)列名 类型 长度 描述rosterID NUMBER n/a 编号名册(主键)username VARCHAR 32 用户名jid TEXT n/a 地址名册入境sub NUMBER n/a 认购地位入境ask NUMBER n/a 卖出

24、地位入境recv NUMBER n/a 检举表明进入名册收到请求nick VARCHAR 255 昵称分配给这个名册入境ofRosterGroups (组的好友名单中的条目)列名 类型 长度 描述rosterID NUMBER n/a 名册编号(主键)#*rank NUMBER n/a 立场项(主键)groupName VARCHAR 255 用户定义的名称,这个名册组ofPrivacyList (用户隐私清单)列名 类型 长度 描述username VARCHAR 32 用户名(主键)name VARCHAR 100 姓名保密清单(主键)isDefault NUMBER n/a 检举指出,如

25、果这是默认隐私的用户名单list TEXT n/a XML 表示的隐私清单ofVCard (电子名片的联系信息)列名 类型 长度 描述username VARCHAR 32 用户名(主键)vcard TEXT n/a 价值的 vCard 入境ofVersion (包含产品版本信息)列名 类型 长度 描述name VARCHAR 50 名称的项目,版本信息正在跟踪的(主键)version INTEGER n/a 版本号ofProperty (服务器属性)列名 类型 长度 描述name VARCHAR 100 属性名称(主键)propValue TEXT n/a 进入值ofExtComponent

26、Conf (外部元件配置)列名 类型 长度 描述subdomain VARCHAR 255 子的外部元件(主键)secret VARCHAR 255 共享密钥的外部元件permission VARCHAR 10 许可,表明如果组件是可以连接到服务器ofRemoteServerConf (远程服务器配置)列名 类型 长度 描述xmppDomain VARCHAR 255 域的外部元件(主键)remotePort NUMBER n/a 港口的远程服务器连接到permission VARCHAR 10 许可,表明如果远程服务器可以连接到服务器ofSecurityAuditLog (伐木安全事件)列名

27、 类型 长度 描述msgID NUMBER n/a 编号审计信息(主键)username VARCHAR 64 使用者谁执行的行动entryStamp NUMBER n/a 时间戳当事件发生summary VARCHAR 255 总结了发生在事件node VARCHAR 255 节点事件发生details TEXT n/a 详细的细节,所发生的ofMucService (甲 Groupchat 服务)列名 类型 长度 描述#*serviceID NUMBER n/a 编号的服务(收录)subdomain VARCHAR 255 子服务(主键)description VARCHAR 255 服务

28、说明isHidden NUMBER n/a 1 ,如果隐藏的管理界面名单, 0 正常ofMucServiceProp (名称值协会的 Groupchat 服务)列名 类型 长度 描述serviceID NUMBER n/a 编号的服务(主键)name VARCHAR 100 属性名称(主键)propValue TEXT n/a 属性值ofMucRoom ( Groupchat 室内资料)列名 类型 长度 描述roomID NUMBER n/a 编号的房间(主键)creationDate VARCHAR 15 创建日期modificationDate VARCHAR 15 最后更新日期name

29、VARCHAR 50 姓名房间用作公共编号naturalName VARCHAR 255 天然名称室description VARCHAR 255 客房描述canChangeSubject NUMBER n/a 检举指出是否可以改变参与者的主题maxUsers NUMBER n/a 马克斯一些房间居住者canChangeSubject NUMBER n/a 检举指出是否与会者可以改变的主题或不publicRoom NUMBER n/a 检举指示是否室将在目录中列出或不moderated NUMBER n/a 检举指示是否室主持或不membersOnly NUMBER n/a 检举指出是否房间是

30、会员制或不canInvite NUMBER n/a 检举指出是否占用可以邀请其他用户roomPassword VARCHAR 50 密码数据加入室canDiscoverJID NUMBER n/a 检举指出是否真正 JID 的居住者是公共或不logEnabled NUMBER n/a 检举指出是否房间谈话记录或不subject VARCHAR 100 最后为人所知的主题房间rolesToBroadcast NUMBER n/a 二元代表的作用,以广播useReservedNick NUMBER n/a 检举指出是否用户只能加入室使用其保留昵称canChangeNick NUMBER n/a 检

31、举指出是否可以改变其占用的空间昵称canRegister NUMBER n/a 检举显示用户是否被允许登记室ofMucRoomProp (名称值协会的 Groupchat 房间)列名 类型 长度 描述roomID NUMBER n/a 编号的房间(主键)name VARCHAR 100 属性名称(主键)propValue VARCHAR 4000 属性值ofMucAffiliation (归属的空间用户)列名 类型 长度 描述roomID NUMBER n/a 编号的房间(主键)#*jid TEXT n/a 用户 JID (主键)affiliation NUMBER n/a 一些代表所属一级o

32、fMucMember (室成员资料)列名 类型 长度 描述roomID NUMBER n/a 编号的房间(主键)jid TEXT n/a 用户 JID (主键)nickname VARCHAR 255 保留昵称的会员ofMucConversationLog (室会话日志)列名 类型 长度 描述roomID NUMBER n/a 编号的空间sender TEXT n/a JID 的用户发送邮件的房间nickname VARCHAR 255 昵称使用时由用户发出的信息logTime VARCHAR 15 日期的消息时,被送到房间subject VARCHAR 50 新的主题改变的信息body TE

33、XT n/a 消息正文ofPubsubNode (节点 pubsub 服务)列名 类型 长度 描述serviceID VARCHAR 100 编号托管服务节点(主键)nodeID VARCHAR 100 编号的节点(主键)leaf NUMBER n/a 检举表明节点是否是叶或收集节点creationDate VARCHAR 15 创建日期modificationDate VARCHAR 15 最后更新日期parent VARCHAR 100 编号的父节点(如果有的话)deliverPayloads NUMBER n/a 检举指出是否有效载荷中包含的通知maxPayloadSize NUMBER

34、 n/a 最大规模的有效载荷的字节persistItems NUMBER n/a 检举表明节点是否将持续出版项目maxItems NUMBER n/a 最大的项目数量将持续notifyConfigChanges NUMBER n/a 检举指出是否发送通知时,该节点的配置发生了变化notifyDelete NUMBER n/a 检举指出是否发送通知时,该节点将被删除notifyRetract NUMBER n/a 检举指出是否发送通知时,发布的项目将被删除presenceBased NUMBER n/a 检举指出是否发送通知只有用户才sendItemSubscribe NUMBER n/a 检举

35、指出是否向去年出版项目,以新用户publisherModel VARCHAR 15 Publisher 中使用的模式的节点subscriptionEnabled NUMBER n/a 检举指出是否允许订阅configSubscription NUMBER n/a 检举指出是否新的订户必须设定为活跃accessModel VARCHAR 10 访问模型所使用的节点payloadType VARCHAR 100 类型的有效载荷数据将提供在节点bodyXSLT VARCHAR 100 网址的一个 XSLT 转换有效载荷的格式为一个邮件正文dataformXSLT VARCHAR 100 网址的一个

36、XSLT 转化的有效载荷格式的数据形式结#*果creator VARCHAR 1024 JID 的实体建立了节点description VARCHAR 255 说明节点language VARCHAR 255 默认语言的节点name VARCHAR 50 名称节点replyPolicy VARCHAR 15 政策界定业主或出版商是否应得到答复项目associationPolicy VARCHAR 15 政策规定谁可以联系叶节点的集合maxLeafNodes NUMBER n/a 马克斯一些叶节点,一个节点可能会收集ofPubsubNodeJIDs ( JIDs 与节点)列名 类型 长度 描述s

37、erviceID VARCHAR 100 编号托管服务节点(主键)nodeID VARCHAR 100 编号的节点(主键)jid VARCHAR 1024 JID 实体(主键)associationType VARCHAR 20 协会类型的节点ofPubsubNodeGroups (名册集团与节点)列名 类型 长度 内容serviceID VARCHAR 100 编号托管服务节点nodeID VARCHAR 100 编号的节点rosterGroup VARCHAR 100 名册组节点所有者可以签署和检索项目ofPubsubAffiliation (节点分支机构)列名 类型 长度 描述servi

38、ceID VARCHAR 100 编号托管服务节点(主键)nodeID VARCHAR 100 编号的节点(主键)jid VARCHAR 1024 JID 的子公司(主键)affiliation VARCHAR 10 所属类别ofPubsubItem (项目发布到节点)列名 类型 长度 描述serviceID VARCHAR 100 编号托管服务节点(主键)nodeID VARCHAR 100 编号的节点(主键)id VARCHAR 100 编号的出版项目(独特的每个节点)(主键)jid VARCHAR 1024 JID 出版商creationDate VARCHAR 15 创建日期paylo

39、ad TEXT n/a XML 的有效载荷包括在出版项目ofPubsubSubscription (订阅节点)列名 类型 长度 描述serviceID VARCHAR 100 编号托管服务节点(主键)nodeID VARCHAR 100 编号的节点(主键)id VARCHAR 100 编号认购(主键)jid VARCHAR 1024 地址接收通知owner VARCHAR 1024 JID 的子公司,拥有认购#*state VARCHAR 15 国家认购(工作流程中的)deliver NUMBER n/a 检举指出是否通知或未启用digest NUMBER n/a 检举表明一个实体是否希望收到

40、通知摘要digest_frequency NUMBER n/a 最低数目的毫秒之间发出任何两个通知消化expire VARCHAR 15 日期在租赁认购将结束或已经结束includeBody NUMBER n/a 检举表明一个实体是否希望收到邮件正文除了有效载荷格式showValues VARCHAR 30 存在这些国家的实体希望收到通知subscriptionType VARCHAR 10 无论是用户订阅的项目或节点(收集节点只)subscriptionDepth NUMBER n/a 收到通知的儿童一定深度(收集节点只)keyword VARCHAR 200 关键字活动必须符合ofPubs

41、ubDefaultConf (默认配置节点)列名 类型 长度 描述serviceID VARCHAR 100 编号托管服务节点(主键)leaf NUMBER n/a 检举指出是否配置属于叶或收集节点(主键)deliverPayloads NUMBER n/a 检举指出是否有效载荷中包含的通知maxPayloadSize NUMBER n/a 最大规模的有效载荷的字节persistItems NUMBER n/a 检举表明节点是否将持续出版项目maxItems NUMBER n/a 最大的项目数量将持续notifyConfigChanges NUMBER n/a 检举指出是否发送通知时,该节点的

42、配置发生了变化notifyDelete NUMBER n/a 检举指出是否发送通知时,该节点将被删除notifyRetract NUMBER n/a 检举指出是否发送通知时,发布的项目将被删除presenceBased NUMBER n/a 检举指出是否发送通知只有用户才sendItemSubscribe NUMBER n/a 检举指出是否向去年出版项目,以新用户publisherModel VARCHAR 15 Publisher 中使用的模式的节点subscriptionEnabled NUMBER n/a 检举指出是否允许订阅accessModel VARCHAR 10 访问模型所使用的

43、节点language VARCHAR 255 默认语言的节点replyPolicy VARCHAR 15 政策界定业主或出版商是否应得到答复项目associationPolicy VARCHAR 15 政策规定谁可以联系叶节点的集合maxLeafNodes NUMBER n/a 马克斯一些叶节点,一个节点可能会收集WEB 服务器Openfire 采用内置的 jetty 作 web 服务器,在启动 AdminConsolePlugin 插件时调用 startup()方法启动 jetty 服务器,9090 为其明文端口,9091 为其加密端口。#*页面处理Openfire 没有采用现在很流行的技术

44、架构(SSH ) ,只使用 JSP+JavaBean,但是它有自己的系统设计,就连日志都是自己做的,没有使用我们熟悉的 log4j。现有的 Openfire 管理控制台可采用插件方式进行扩展(详见插件开发说明部分介绍),页面采用 Jsp 方式实现,页面直接调用业务处理逻辑类(通常命名为 XXManager)的实例方法,通常通过 request 对象封装的方式传递页面展现判定变量,常出现本页跳转。每个插件可定义自己的 Servlet 类和 web.xml及 web-custom.xml 配置文件。采用装饰框架方式展现页面,decorator 页面有两个,即src/web/decorators 目

45、录下的两个页面 main.jsp 和 setup.jsp。采用自定义的admin 标签实现,标签库 admin.tld 放置在 src/web/WEB-INF 目录下,标签解析类放置在 org.jivesoftware.admin 包下,有SidebarTag、SubnavTag、SubSidebarTag、TabsTag 四个解析类。在调用loadPlugin()方法进行插件加载时,解析插件的 plugin.xml 配置文件,将获取的相关信息封装在 AdminConsole 类的 generatedModel 对象中,后期通过插件解析类提取该对象中的数据并配合 sitemesh 装饰器进行页

46、面展现。详见“使用 dom4j设计 Openfire 式导航菜单 ”部分相关介绍。插件开发Openfire Plugins 加载流程#*官方插件开发说明所有插件都存放在 openfire 根下的 plugins 目录下。当一个插件被以 JAR或 WAR 文件发布时,他自动扩展为一个文件夹。插件目录结构如下所示: Plugin Structuremyplugin/|- plugin.xml plugin.ItviTestPluginThis is an example plugin.Jive Software1.007/01/2006http:/www.igniterealtime.org/pr

47、ojects/openfire/plugins.jsp3.0.0gpl#*各元数据域能在 plugin.xml 文件中进行设置: name 插件名. description 插件描述. author 插件作者. version 插件版本. date 插件版本生成日期。该日期必须为 MM/dd/yyyy 格式, 如07/01/2006. url 关于该插件的更多详细信息可以从该地址获取. minServerVersion 为运行该插件所需的最低的 Openfire 软件版本(Openfire 2.1.2 及后续版本支持该选项).如果服务器版本低于需要的最低版本,插件将不会启动. database

48、Key 如果插件需要它自己的数据库表,必须将 databaseKey元素设置为一个 schema key name(通常与插件同名). 然后需将所有需支持数据库类型的数据库 schema 文件放到插件的 database 文件夹下. 例如,给一个关键字“foo”,那么 schema 文件需命名为“foo_mysql.sql“, “foo_oracle.sql“等.我们建议你在命名你的表时加上前缀“of“ (openfire),以避免与其他可能使用同一数据库的其他应用系统需要的表产生冲突.关于版本的描述信息需添加到 ofVersion 表中,以对应的 key 做标识,这样可以跟踪 schema 版本信息,如:INSERT INTO ofVersion (name, version) VALUES (foo, 0); databaseVersion 数据库 schema 版本(如果定义了数据库 schema)。有数据库 schema 的新插件的版本从 0 开始编号。如果以后的插件版本需要更新 schema,这些更新能通过在 database/upgrade 目录下为各版本创建子目录的方式来定义。例如目录 database/upgrade/1 和database/upgrade/2 将包括如 “foo_mysql.sql“和“foo_oracle.sql“ 这样的包含各版本相应的数据

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 专业基础教材

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报