=======20160627 Begin ========
更正:通过多次尝试,和openfire源码分析,发现openfire是不能以插件形式替换默认登录机制的.会提示找不到自定义的Provider,因为openfire查找Provider会在openfire/lib目录下查找,并不会在openfire/plugins/下查找.所以解决方法是:把写好的Provider打成jar包,放到openfire/lib下,再替换默认的登录机制,即可实现登录机制替换.
替换后,会出现不少问题.具体的问题可以根据异常方法栈找到解决方法,一般是因为:换了登录机制后,必须要重写许多方法,比如createUser等,否则,当你在控制台上新建用户时,就会出现异常.
=======20160627 End========
前言:
我的openfire使用的是内置的数据库,如果不是内置的数据库,解决方案也类似.
亲,如果你还不会配Openfire,或是还不会写openfire的 插件,或是还不会用Ant编译插件,可以参看我转载的这篇文章:http://blog.csdn.net/lc0817/article/details/51379432
先说说我是如何替换默认登录机制的(如果你不关心过程,只关心结果,可以跳过前言部分)
1.通过百度,发现客户端认证与UserProvider,AuthProvider这个两接口有关.(这里只分析UserProvider,authProvider类似)
2.利用Eclipse,找到UserProvider接口的所