转自:http://blog.csdn.net/nomousewch/article/details/7546083

在最近的项目中使用openfire服务器实现消息推送功能,如果使用openfire自带的用户表,需要维护两张用户表,不是很方便,如果openfire能够直接使用现有系统的用户表就方便多了,而事实上openfire已经为我们考虑到了这一点,我们只需要做一些相关配置就可以了。

  • 原理
研究了下openfire的源码,发现实现此点的关键在于data provider的应用,简单来说,就是在程序中需要用到持久化数据(比如用户名、部门名这些,可以储存在数据库中,也可以储存在xml文件或者ldap目录服务中)的地方,用一个Provider作为获取数据的统一接口,针对不同的数据源(可以是数据库的不同表,也可以是nosql、xml等其它数据源)进行相应的实现,比如其中AuthProvider接口(负责用户验证),它有两个不同的实现DefaultAuthProvider和JDBCAuthProvider ,前者是默认的openfire自带表,而后者则是根据我们自定义的数据表,我们将默认的DefaultAuthProvider配置为JDBCAuthProvider ,并添加一些配置文本,就可以进行数据源的切换了。
  • 具体配置

进入openfire管理控制台-服务器-服务管理器-系统属性

增加以下键值对,或者在数据库中直接更新数据表

  1. --设置JDBC连接方式
  2. insertinto OFPROPERTY (NAME, PROPVALUE)
  3. values ('jdbcProvider.connectionString',
  4. 'jdbc:oracle:thin:@10.35.246.178:1521:orcl');
  5. insertinto OFPROPERTY (NAME, PROPVALUE)
  6. values ('jdbcProvider.driver', 'oracle.jdbc.driver.OracleDriver');
  7. --设置管理员账号
  8. insertinto OFPROPERTY (NAME, PROPVALUE)
  9. values ('admin.authorizedJIDs', 'admin@localhost');
  10. --自定义用户认证
  11. insertinto OFPROPERTY (NAME, PROPVALUE)
  12. values ('jdbcAuthProvider.useConnectionProvider', 'true');
  13. insertinto OFPROPERTY (NAME, PROPVALUE)
  14. values ('jdbcAuthProvider.passwordSQL', 'select ''123456'' as pwd from
  15. t_sys_user t where t.code=?');
  16. insertinto OFPROPERTY (NAME, PROPVALUE)
  17. values ('jdbcAuthProvider.passwordType', 'plain');
  18. --自定义用户管理
  19. insertinto OFPROPERTY (NAME, PROPVALUE)
  20. values ('jdbcUserProvider.allUsersSQL', 'select code from t_sys_user
  21. t');
  22. insertinto OFPROPERTY (NAME, PROPVALUE)
  23. values ('jdbcUserProvider.nameField', 'name');
  24. insertinto OFPROPERTY (NAME, PROPVALUE)
  25. values ('jdbcUserProvider.searchSQL', 'select code from t_sys_user t
  26. where code=?');
  27. insertinto OFPROPERTY (NAME, PROPVALUE)
  28. values ('jdbcUserProvider.useConnectionProvider', 'true');
  29. insertinto OFPROPERTY (NAME, PROPVALUE)
  30. values ('jdbcUserProvider.emailField', 'email');
  31. insertinto OFPROPERTY (NAME, PROPVALUE)
  32. values ('jdbcUserProvider.userCountSQL', 'selectcount(*) from
  33. t_sys_user t');
  34. insertinto OFPROPERTY (NAME, PROPVALUE)
  35. values ('jdbcUserProvider.loadUserSQL', 'select t.name,t.email,t.code
  36. from t_sys_user t where t.code=?');
  37. insertinto OFPROPERTY (NAME, PROPVALUE)
  38. values ('jdbcUserProvider.usernameField', 'code');
  39. --使用不同的数据源
  40. update OFPROPERTY set
  41. PROPVALUE='org.jivesoftware.openfire.user.JDBCUserProvider'
  42. whereNAME='provider.user.className';
  43. update OFPROPERTY set
  44. PROPVALUE='org.jivesoftware.openfire.auth.JDBCAuthProvider'
  45. whereNAME='provider.auth.className';
  46. commit;

openfire使用自定义用户表的更多相关文章

  1. 第四百零六节,自定义用户表类来继承Django的用户表类,

    第四百零六节,自定义用户表类来继承Django的用户表类, models.py from django.db import models # Create your models here. from ...

  2. django自定义用户表

    django中已经给我生成默认的User表,其中的字段已经可以满足我们的日常需求. 但有时候,我们需要更多的字段,我们就可以自定义.来替换django自带的User表. #models.py from ...

  3. django 自定义用户表替换系统默认表

    首先新建一个users应用,编写这个应用的models类. from django.contrib.auth.models import AbstractUser class UserProfile( ...

  4. Django自定义用户认证

    自定义一个用户认证 详细参考官方文档: https://docs.djangoproject.com/en/1.9/topics/auth/customizing/#django.contrib.au ...

  5. spring security方法一 自定义数据库表结构

    Spring Security默认提供的表结构太过简单了,其实就算默认提供的表结构很复杂,也无法满足所有企业内部对用户信息和权限信息管理的要求.基本上每个企业内部都有一套自己的用户信息管理结构,同时也 ...

  6. 把sql server 2000的用户表的所有者改成dbo

    怎么样把sql server 2000的用户表的所有者,改成dbo,而不是用户名. 推荐使用下面介绍的第二种方法,执行以下查询便可以了.sp_configure 'allow updates','1' ...

  7. 如何利用WordPress创建自定义注册表单插件

    来源:http://www.ido321.com/1031.html 原文:Creating a Custom WordPress Registration Form Plugin 译文:创建一个定制 ...

  8. Sqlserver如何递归查询层级数据将父级字段和本级某个字段合并?如何自定义用户函数并调用?

    开门见山,首先说下遇到的问题:前期系统地区字典表中,每个省市县只存了本级名称,没存完整的字段.如:肥西县隶属安徽省合肥市,表中就存了一个肥西县.现有需求需要将完整字段显示,由于系统已在线上运营,无法做 ...

  9. CMDB资产管理系统开发【day25】:Django 自定义用户认证

    官方文档:https://docs.djangoproject.com/en/1.10/topics/auth/customizing/#substituting-a-custom-user-mode ...

随机推荐

  1. Huffman Tree

    哈夫曼(Huffman)树又称最优二叉树.它是一种带权路径长度最短的树,应用非常广泛. 关于Huffman Tree会涉及到下面的一些概念: 1. 路径和路径长度路径是指在树中从一个结点到另一个结点所 ...

  2. snprintf 使用注意

    #include <iostream> #include <cstdio> // 包含的头文件 using namespace std; int main(int argc, ...

  3. .NET 泛型

    泛型      泛型将类型参数的概念引入 .NET Framework,类型参数使得设计如下类和方法成为可能:这些类和方法将一个或多个类型的指定推迟到客户端代码声明并实例化该类或方法的时候.例如,通过 ...

  4. ios原声音频播放AVAudioSession 总结

    //音频播放/*英译:record:录音 */ 1 导入头文件#import<AVFoundation/AVFoundation.h>//AVAudioSession是一个单例模式.在IO ...

  5. CSC321 神经网络语言模型 RNN-LSTM

    主要两个方面 Probabilistic modeling 概率建模,神经网络模型尝试去预测一个概率分布 Cross-entropy作为误差函数使得我们可以对于观测到的数据 给予较高的概率值 同时可以 ...

  6. WPF中Ribbon控件的使用

    这篇博客将分享如何在WPF程序中使用Ribbon控件.Ribbon可以很大的提高软件的便捷性. 上面截图使Outlook 2010的界面,在Home标签页中,将所属的Menu都平铺的布局,非常容易的可 ...

  7. JVM调优总结 -Xms -Xmx -Xmn -Xss

    http://blog.csdn.net/ye1992/article/details/9344807 堆大小设置JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit) ...

  8. Codeforces Round #367 (Div. 2)

    A题 Beru-taxi 随便搞搞.. #include <cstdio> #include <cmath> using namespace std; int a,b,n; s ...

  9. nodejs review-03

    39 Serve different file types with our server 处理文件类型 function content_type(filename) { var ext = pat ...

  10. DataTable.RowFilter 用法

    /// <summary> /// 处理DataRow筛选条件的特殊字符 /// </summary> /// <param name="rowFilter&q ...