iOS - XMPP Openfire 服务器的搭建
前言
提前下载好相关软件,且安装目录最好安装在全英文路径下。如果路径有中文名,那么可能会出现一些莫名其妙的问题。
提前准备好的软件:
在安装配置 Openfire 或其他 xmpp 服务器前,需要先安装 MySQL 数据库。
- MySQL 安装具体讲解见 iOS - MySQL 的安装配置。
1、下载安装 Openfire
在 Openfire 官网下载最新的 Mac 版本 Openfire 安装包。

下载完后双击安装包,点击 pkg 文件,在安装引导下进行傻瓜式安装。安装完成后,进入系统偏好设置,点击 Openfire 图标。

进入 Openfire 偏好设置界面。点击 Start Openfire,让 OpenFire 服务开始启动(默认是启动的),启动完毕后,我们就可以点击 Administration 下的按钮,进入服务器后台,然后会要求输入管理员账号密码。

Openfire 服务启动不了问题解决
安装好之后,第一次是可以启动 openfire 服务器的,但是电脑重启后,就再也不能启动服务器了,每次一点击 “Start Openfire”,然后加载一下,状态还是 “Start Openfire” 没变化,有时甚至还会跳出错误提示框,提示 “Could not start the Openfire server”。
解决方案如下:
1)首先需要确认是否已经安装了 Java 的运行环境,以及 JAVA jdk 是否与当前 OS 系统版本,Openfire 版本成对应,如果不是,就请先安装相匹配对应的软件。
- 在终端中输入
java -version,就可以查看电脑有没有安装 JAVA 运行环境。
- 在终端中输入
2)如果软件,环境对应的,最终的解决办法是
打开终端,输入以下命令:
// 获取 Openfire 目录的访问权限 sudo chmod -R 777 /usr/local/openfire/bin // 以超级管理员的权限运行脚本 sudo su cd /usr/local/openfire/bin // 设置 Java 的环境变量 export JAVA_HOME=`/usr/libexec/java_home` // 输出检验环境变量的值 echo $JAVA_HOME输入上面的命令后回车,就会出现后面的这些语句
/Library/Java/JavaVirtualMachines/jdk1.8.0_51.jdk/Contents/Home
接着在终端,输入以下命令:
cd /usr/local/openfire/bin // 运行 Openfire shell 脚本 ./openfire.sh输入上面的命令后回车,就会出现后面的这些语句
Openfire 4.1.2 [2016-2-21 2:47:51] 管理平台开始监听: http://jhq0228-macbookair.local:9090 https://jhq0228-macbookair.local:9091 Successfully loaded plugin 'admin'.
执行完这些命令之后,服务器就可以启动了,每次开机后,都启动不了的话,都试下这个方法。
2、配置 Openfire
- 在 Openfire 偏好设置界面中,点击 Open Admin Console,进入 web 配置页面,开始配置 Openfire 服务器。
2.1 选择语言
简体中文

2.2 服务器设置
域:如果只是本地机器上登录,可以设置为本地的域 127.0.0.1。需要远端登录的话,设置为相应的 IP 地址或域名即可。此处设置为 Mac 的机器名。
Server Host Name (FQDN):服务器名,不能为 IP 地址。

2.3 数据库设置
1、选择数据库
如果要设置外部数据库(推荐,比如:MySQL),选择标准数据库连接。

前期 MySQL 数据库准备工作
MySQL 安装具体讲解见 iOS - MySQL 的安装配置。
1)设置 /usr/local/openfire 文件夹的访问权限为可读写

方法1:在 finder 中前往文件夹 /usr/local/,右键 openfire 文件夹,显示简介,点击如图右下角中的锁图标解锁,并设置权限为可以读写。
方法2:打开终端,输入如下命令
$ sudo chmod 777 /usr/local/openfire- 其中 777 表示授权可读写权限,000 表示无访问权限。
2)在终端中登陆 MySQL,输入以下命令,然后输入数据库的 root 密码登录
$ mysql -u root -p回车后,终端输出
Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 946 Server version: 5.7.17 MySQL Community Server (GPL) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
3)在终端输入以下命令,创建数据库 openfire
create database openfire;回车后,终端输出
Query OK, 1 row affected (0.03 sec)
4)在终端输入以下命令,导入 openfire 资源文件夹 resources/database 下的数据表
use openfire; source /usr/local/openfire/resources/database/openfire_mysql.sql在终端出现一排导入过程

5)在终端输入以下命令,刷新权限
flush privileges;回车后,终端输出
Query OK, 0 rows affected (0.07 sec)
6)在终端输入以下命令,退出 MySQL
exit
2、设置数据库连接
设置标准数据库连接

1)数据库驱动选项
- 选择 MySQL,前提是已安装 MySQL。
2)JDBC 驱动程序类
默认不变,默认为:
com.mysql.jdbc.Driver
3)数据库 URL
形式如下:
jdbc:mysql://你的主机名:端口号/数据库名称 jdbc:mysql://[host-name]:3306/[database-name]?rewriteBatchedStatements=true- [host-name] :主机名
- [database-name]:数据库名称
这里设置为:
jdbc:mysql://localhost:3306/openfire- 其中主机名 [host-name] 改为 localhost。
- 其中数据库名称 [database-name] 改为 openfire。
解决数据库字符编码问题,可以在后面加
?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8最终的 url 形式是
jdbc:mysql://localhost:3306/openfire?useUnicode=true&characterEncoding=UTF-8&characterSetResults=UTF-8注意:前提是已存在一个名为 openfire 的数据库,否则会报如下错误,连接配置不成功。openfire 数据库的创建具体见前面所讲的 “前期 MySQL 数据库准备工作”。
- The Openfire database schema does not appear to be installed. Follow the installation guide to fix this error.
4)用户名和密码
- 这里的用户名密码,是访问 MySQL 数据库时使用的帐号:root,和安装 MySQL 设置的 root 密码。
2.4 特性设置
如果不打算使用 LDAP,则保持默认设置即可。

特性设置时出错问题解决

解决方法
- 在 OpenFire 偏好设置中重启 OpenFire,然后重新进入 OpenFire web 配置页面,重新开始配置 Openfire 服务器即可。
2.5 管理员账户设置
可以随便填写一个管理员邮箱,输入要设置的密码即可。管理员账号默认为 "admin",如果不设置密码,则默认密码为 "admin"。

自定义管理员账户名方法
在终端输入以下命令,输入数据库的 root 密码,登陆具体的数据库(openfire)
mysql -u root -p openfire删除表 “ofUser” 中的 admin 帐户
delete from ofUser where username = 'admin';创建自定义管理员(用户名:qianchia,密码:123456)
insert into ofUser (username, plainPassword, encryptedPassword, name, email, creationDate, modificationDate) values('qianchia','123456','123456','Administrator','qianchia@icloud.com','0','0');查看用户
select * from ofUser;如果可以往数据库里插入用户但是在用户摘要却没有数据,这是因为 openfire 的数据库驱动包太旧了,而安装的数据库太新了,把 openfire 里的驱动包换成新的就行了,路径:/usr/local/openfire/lib。

2.6 登陆管理控制台
完成安装后可以输入用户名和密码登陆管理控制台

默认的管理员帐号是 “admin”,默认管理员密码 “admin”,如果上面设置了新密码,则管理员密码是新密码。如果重设了用户名,必须重启 openfire 服务器。


无法登录管理控制平台问题解决
安装 Openfire 后 admin 无法登录管理控制平台。登录时提示:Login failed:make sure your username and password are correct and that you’re an admin or moderator。
解决方案如下:
1)使用 MySQL 查看工具进入数据库,进入表 “ofuser”,将该表清空,然后执行该 SQL
INSERT INTO ofUser (username, plainPassword, name, email, creationDate, modificationDate) VALUES ('admin', 'admin', 'Administrator', 'admin@example.com', '0', '0');2)关闭 Openfire 服务,就是从其控制台 stop 然后再 start,再用用户名:admin,密码:admin 登录即可。
每次重启 Mac 电脑都需要重新配置 Openfire 问题解决
解决方法:
打开 /usr/local/openfire/conf/ 文件夹。
将 openfire.xml 和 security.xml 两个文件的权限设置为读与写。
重新完成 Openfire 配置。
3、卸载 Openfire 方法
1、卸载之前首先要停止 Openfire 服务。
系统偏好中点击 Openfire 图标,如下图

在 Openfire 偏好设置界面中,点击 Stop Openfire。

2、删除 Openfire 文件。
在终端里,输入以下三条命令执行即可。
sudo rm -rf /Library/PreferencePanes/Openfire.prefPane以上执行后需要输入管理员密码。
sudo rm -rf /usr/local/openfire sudo rm /Library/LaunchDaemons/org.jivesoftware.openfire.plist
4、测试服务器
4.1 添加测试账户
服务器配置完成之后,我们可以创建几个用户,然后客户端可以使用这些用户信息登录,互相传输消息。


4.2 XMPP 客户端设置与使用
有许多通信聊天客户端可以支持 XMPP 协议,比如,Mac 电脑就自带了一个 “信息” app,“信息” app 就支持 jabber 通信协议(XMPP 的别名)。
打开 Mac 的 “信息” app,点击菜单 信息 -> 添加账户,选择其他 “信息” 账户...

选择 jabber 账户类型,填写相关信息

- 账户类型:Jabber
- 用户名:上边添加的测试账户名,格式必须为:
名称@openfire服务器名称 - 密码:用户名对应的密码
- 服务器:openfire 服务器地址,可以使用自动查找服务器和端口
- 端口:openfire 服务器客户端端口
然后,提示验证证书,选择继续。

登录成功。

登录成功后在 openfire 服务器端可以看到用户的登录状态。

iOS - XMPP Openfire 服务器的搭建的更多相关文章
- iOS xmpp Openfire+spark环境搭建
配置这个遇到太多问题了,写下来分享 首先到官网下载openfire+spark 下载地址:http://www.igniterealtime.org/downloads/index.jsp
- openfire服务器+Spark搭建即时聊天系统 & 阿里云的初步探索
晚上出去和洋仔吃了涮肉,喝了点啤酒,不知不觉就聊到了11点,感觉他工作状态还不错,emmm...都要加油吧.虽然没有当时去山西零下二十多度那么夸张,这几天北京的冬夜还是有点小冷的.好了进入正题: 一. ...
- (转)基于即时通信和LBS技术的位置感知服务(三):搭建Openfire服务器+测试2款IM客户端
主要包含4个章节: 1. Java 领域的即时通信的解决方案 2. 搭建 Openfire 服务器 3. 使用客户端测试我们搭建的 Openfire 服务器 4. Smack 和 ASmack 一.J ...
- IOS即时通讯XMPP搭建openfire服务器
一.下载并安装openfire 1.到http://www.igniterealtime.org/downloads/index.jsp下载最新openfire for mac版 比如:Openfir ...
- IOS即时通讯XMPP搭建openfire服务器 分类: ios技术 2015-03-07 11:30 53人阅读 评论(0) 收藏
一.下载并安装openfire 1.到http://www.igniterealtime.org/downloads/index.jsp下载最新openfire for mac版 比如:Openfir ...
- XMPP之ios即时通讯客户端开发-mac上搭建openfire服务器(二)
come from:http://www.cnblogs.com/xiaodao/archive/2013/04/05/3000554.html 一.下载并安装openfire 1.到http://w ...
- ios即时通讯客户端开发之-mac上搭建openfire服务器
一.下载并安装openfire 1.到http://www.igniterealtime.org/downloads/index.jsp下载最新openfire for mac版 比如:Openfir ...
- 基于XMPP协议(openfire服务器)的消息推送实现
转自:http://blog.csdn.net/nomousewch/article/details/8088277 最近好像有不少朋友关注Android客户端消息推送的实现,我在之前的项目中用到过J ...
- iOS,XMPP本地环境搭建和框架使用
1.XMPP的MySQL和openfire环境配置 2.XmppFramework框架导入和介绍 XMPP的MySQL和openfire环境配置 1.下载mysql安装 mysql下载 打开MySQL ...
随机推荐
- CF 291E. Tree-String Problem [dfs kmp trie图优化]
CF291E 题意:一棵树,每条边上有一些字符,求目标串出现了多少次 直接求目标串的fail然后一边dfs一边跑kmp 然后就被特殊数据卡到\(O(n^2)\)了... 因为这样kmp复杂度分析的基础 ...
- 二维码开源库ZBar-实现中文解码
中文乱码 上篇<ZBar-windows下编译和使用>已经成功解析了条形码,但目标是二维码,经测试二维码中文会出现乱码.下图二维码的内容是"http123测试456", ...
- 构建企业级Nginx+Keepalived集群架构
随着Nginx在国内的发展潮流,越来越多的互联网公司都在使用Nginx. Nginx高性能.稳定性成为IT人士青睐的http和反向代理服务器,今天我们来实战构建Nginx+Keepalived高可用架 ...
- Docker 中国官方镜像加速
参考:https://www.docker-cn.com/registry-mirror 通过 Docker 官方镜像加速,中国区用户能够快速访问最流行的 Docker 镜像.该镜像托管于中国大陆,本 ...
- Chrome Stylist 插件 (CSS备份)
Stylist 插件还是很好用的,可以给网站自定义CSS样式,(还有个插件叫"油猴子",可以给网页加载自定义JS): 不过麻烦的是,现在的最新版360浏览器不能显示这个插件(这个浏 ...
- PHP入门学习精要
一.文件名 函数.配置文件等其他类库文件之外的一般是以.php为后缀(第三方引入的不做要求): ThinkPHP的模板文件默认是以.html 为后缀(可以通过配置修改): 二.其它命名 其它命名 规则 ...
- 10分钟入门kubernetes(上)
kubernetes简称k8s, 主要用途是automate deployment, scaling, and managment of containerized applications.是目前非 ...
- HTML5VEDIO标签阿里云-微信浏览器兼容性问题
在网页展示媒体对象,离不开HTML5的 audio和video对象.但这两个目前来看兼容性方面还得关注一下. 目前在做一个阿里云下载video 并在微信端播放mp4格式的视频的时候,碰到了一些兼容性问 ...
- 报错信息 The jsp:param action must not be used outside the jsp:include, jsp:forward, or jsp:params elements 的原因及解决办法
如果你的代码是这样的话就会报错 <jsp:forward page="02.jsp"></jsp:forward> <jsp:param value= ...
- 验证SQLServer死锁进程
SELECT '现在没有阻塞和死锁信息' AS message -- 循环开始WHILE @intCounter <= @intCountProperties BEGIN-- 取第一条记录 SE ...