转自: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. 根据字符长度动态确定UIlabel宽高

    iOS7中用以下方法 - (CGSize)sizeWithAttributes:(NSDictionary *)attrs; 替代过时的iOS6中的- (CGSize)sizeWithFont:(UI ...

  2. poj 2955 Brackets

    题目链接:http://poj.org/problem?id=2955 思路:括号匹配问题,求出所给序列中最长的可以匹配的长度(中间可以存在不匹配的)例如[(])]有[()]符合条件,长度为4 dp[ ...

  3. winform TreeView的一些用法以及异步加载

    今天,主要弄了一下对于树型控件的一些方法,以及异步加载.参考: http://www.cnblogs.com/greatverve/archive/2012/03/23/winform-treevie ...

  4. php多文件上传

    多文件上传<input type="file" name="file[]" multiple /> <?php function reArra ...

  5. CSS3样式运用,悬浮立体方块

    前言 作为后端开发者,了解前端是必须的,所以自己琢磨着弄了弄一个CSS3的阴影运用. 我记得这应该是以前淘宝用过的,PS:现在跑到淘宝去看,好像没有找到了.现在流行扁平化设计,没有了阴影,没有了立体! ...

  6. MSSQ调优所需用的语句

    看一下各项指标是否正常,是否有阻塞,这个语句选取了前10个最耗CPU时间的会话语句 [session_id], [request_id], [start_time] AS '开始时间', [statu ...

  7. 论SOA架构的几种主要开发方式

    转: http://blog.csdn.net/chenleixing/article/details/44926955  面向服务架构soa以其独特的优势越来越受到企业的重视,它可以根据需求通过网络 ...

  8. BFC的深入理解

    一:BFC是什么东东 了解BFC前先一了解一下Box和Formatting Context (1)B: BOX即盒子,页面的基本构成元素.分为 inline . block 和 run-in 三种类型 ...

  9. nodejs review-01

    lesson lesson-code 05 Run your first web server 使用curl //指定方法;显示header信息 curl -X GET -i localhost:30 ...

  10. 【DP】HIHO 1078

    HIHO #1037 : 数字三角形 题意:中文题就不说了. 思路:提示也很清楚,就这里贴一下代码.注意边界情况. dp[i][j] = max(dp[i-1][j],dp[i-1][j-1])+ma ...