来自另一个数据库的Xmpp用户登录身份验证
我是XMPP新手,最近我通过在MySql中定义IP(localhost)、端口(5222)和名为:openfire的新数据库安装并配置了openfire管理控件 但是我的用户名和密码在另一个数据库中,是否需要在openfire中进行配置,以便它可以在我自己创建的数据库中检查用户身份验证,而不是检查用户的(openfire)自己创建的usertable 我在这里添加标签来自另一个数据库的Xmpp用户登录身份验证,xmpp,openfire,Xmpp,Openfire,我是XMPP新手,最近我通过在MySql中定义IP(localhost)、端口(5222)和名为:openfire的新数据库安装并配置了openfire管理控件 但是我的用户名和密码在另一个数据库中,是否需要在openfire中进行配置,以便它可以在我自己创建的数据库中检查用户身份验证,而不是检查用户的(openfire)自己创建的usertable 我在这里添加标签 <?xml version="1.0" encoding="UTF-8"?> <!-- This f
<?xml version="1.0" encoding="UTF-8"?>
<!--
This file stores bootstrap properties needed by Openfire.
Property names must be in the format: "prop.name.is.blah=value"
That will be stored as:
<prop>
<name>
<is>
<blah>value</blah>
</is>
</name>
</prop>
Most properties are stored in the Openfire database. A
property viewer and editor is included in the admin console.
-->
<!-- root element, all properties must be under this element -->
<jive>
<adminConsole>
<!-- Disable either port by setting the value to -1 -->
<port>9099</port>
<securePort>9091</securePort>
</adminConsole>
<locale>en</locale>
<!-- Network settings. By default, Openfire will bind to all network interfaces.
Alternatively, you can specify a specific network interfaces that the server
will listen on. For example, 127.0.0.1. This setting is generally only useful
on multi-homed servers. -->
<!--
<network>
<interface></interface>
</network>
-->
<connectionProvider>
<className>org.jivesoftware.database.DefaultConnectionProvider</className>
</connectionProvider>
<database>
<defaultProvider>
<driver>com.mysql.jdbc.Driver</driver>
<serverURL>jdbc:mysql://localhost:3306/openfire?rewriteBatchedStatements=true</serverURL>
<username encrypted="true">87d776abae54f5b4c95c78b78420a6967a9429e9e6d7a5c0</username>
<password encrypted="true">7a1603cafdfe1383ea0e284360172ca8c94b37314dbd5390</password>
<testSQL>select 1</testSQL>
<testBeforeUse>false</testBeforeUse>
<testAfterUse>false</testAfterUse>
<minConnections>5</minConnections>
<maxConnections>25</maxConnections>
<connectionTimeout>1.0</connectionTimeout>
</defaultProvider>
</database>
<jdbcProvider>
<driver>com.mysql.jdbc.Driver</driver>
<connectionString>jdbc:mysql://localhost:3306/mydb?user=root;password=root</connectionString>
</jdbcProvider>
<provider>
<auth>
<className>org.jivesoftware.openfire.auth.JDBCAuthProvider</className>
</auth>
<user>
<className>org.jivesoftware.openfire.user.JDBCUserProvider</className>
</user>
</provider>
<jdbcAuthProvider>
<passwordSQL>SELECT upwd FROM users WHERE uname=? and usertype=2 and delflag=0</passwordSQL>
<passwordType>md5</passwordType>
</jdbcAuthProvider>
<jdbcUserProvider>
<loadUserSQL>SELECT CONCAT(ufname,ulname) AS name,uemail as email FROM users WHERE uname=? AND usertype=2 AND delflag=0</loadUserSQL>
<userCountSQL>SELECT COUNT(*) FROM users WHERE usertype=2 AND delflag=0 AND inactive=0</userCountSQL>
<allUsersSQL>SELECT uname FROM users WHERE usertype=2 AND delflag=0 AND inactive=0</allUsersSQL>
<searchSQL>SELECT uname FROM users WHERE usertype=2 AND delflag=0 AND inactive=0</searchSQL>
<usernameField>uname</usernameField>
<nameField>ufname</nameField>
<emailField>uemail</emailField>
</jdbcUserProvider>
<setup>true</setup>
</jive>
9099
9091
EN
org.jivesoftware.database.DefaultConnectionProvider
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/openfire?rewriteBatchedStatements=true
87d776abae54f5b4c95c78b78420a6967a9429e9e6d7a5c0
7a1603cafdfe1383ea0e284360172ca8c94b37314dbd5390
选择1
错误的
错误的
5.
25
1
com.mysql.jdbc.Driver
jdbc:mysql://localhost:3306/mydb?user=root;密码=根
org.jivesoftware.openfire.auth.jdbauthProvider
org.jivesoftware.openfire.user.JDBCUserProvider
从用户中选择upwd,其中uname=?并且usertype=2和delflag=0
md5
选择CONCAT(ufname,ulname)作为名称,选择uemail作为来自用户的电子邮件,其中uname=?并且usertype=2和delflag=0
从usertype=2、delflag=0和inactive=0的用户中选择COUNT(*)
从usertype=2、delflag=0和inactive=0的用户中选择uname
从usertype=2、delflag=0和inactive=0的用户中选择uname
uname
ufname
电子邮件
符合事实的
这是一份正式的openfire文档,用于您的具体案例:
首先,编辑openfire.xml不会对您的openfire进行任何预期更改。即使你重新启动它 您应该从服务器->系统属性编辑该配置。也可以直接在属性值中修改数据库
但是要小心。。如果使用自己的用户表,我的JDBC身份验证似乎都不起作用。即使我将其设置为普通密码。他们的MD5看起来与standart MD5哈希方法不同我已经完成了使用上述URL的所有步骤,我能够启动openfire,但它仍然没有显示或验证其他用户。在启动过程中没有发现错误或日志。我在主要问题上添加了conf/openfire.xml,请告诉我是否有任何错误。