转自: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. .NET LINQ查询操作中的类型关系

    LINQ 查询操作中的类型关系      若要有效编写查询,您应该了解完整的查询操作中的变量类型是如何全部彼此关联的. 如果您了解这些关系,就能够更容易地理解文档中的 LINQ 示例和代码示例. 另外 ...

  2. LeetCode 26 Remove Duplicates from Sorted Array

    Problem: Given a sorted array, remove the duplicates in place such that each element appear only onc ...

  3. SpringBoot实战配置

    http://blog.csdn.net/sun_t89/article/details/51944252 http://www.cnblogs.com/kreo/p/4423362.html

  4. MongoDB游标操作(4)

    游标是什么? 通俗的说,游标不是查询结果,而是查询的返回资源,或者接口. 通过这个接口,你可以逐条读取. 声明游标: var cursor =  db.collectioName.find(query ...

  5. 【Java EE 学习 16 下】【dbutils的使用方法】

    一.为什么要使用dbutils 使用dbutils可以极大程度的简化代码书写,使得开发进度更快,效率更高 二.dbutils下载地址 http://commons.apache.org/proper/ ...

  6. Oracle资源管理器(二)-- 创建和使用数据库资源计划

    (参考 http://blog.csdn.net/mrluoe/article/details/7969436 -- 整理并实践通过) 第1步,创建3个用户 SQL> create user s ...

  7. fabric devenv Vagrantfile配置

    Vagrantfile文件只会在第一次执行vagrant up时调用执行,其后如果不明确使用vagrant reload,则不会被强制重新加载. # This is the mount point f ...

  8. 【转】如何提高意志力&如何坚持每天学习

    第一篇如何提高意志力 有一种品质可以使一个人在碌碌无为的平庸之辈中脱颖而出,这个品质不是天资,不是教育,也不是智商,而是自律.有了自律,一切皆有可能,无,则连最简单的目标都显得遥不可及.–西奥多·罗斯 ...

  9. CodeForces 279D The Minimum Number of Variables 题解

    题目大意: 有一组n个不相同的数字组成数串:a1,a2,a3-an. 1.一个数组b. 2.第一个操作我们将b0的值赋为a1.之后我们有n-1个操作,第k次操作我们将by=bi+bj(y,i,j可能相 ...

  10. 单元测试地二蛋 先弄个两个原生模块1个原始的一个jq插件

    放羊测试测完了再测这两个瞎搞的下拉列表组建 看看从单元测试模块化的角度组建会写成啥样 1:ajax请求 简单文本     2:1个页面多个实例     3:复杂展示+自定义点击+自定义处理函数     ...