之前开发的项目中实用到IM聊天功能。可是这块功能公司有专门的IM团队来开发,由他们开发好后。直接接入到我们APP中。我參与写IM相关功能非常地少,所以也一直想学习相关知识 。

眼下Android主要用的是XMPP协议及OPenfireserver来实现IM功能,我也从这块入手学习。也感谢全部分享资料让我有机会学习的同行们。

如今正式開始啦。

第一步:搭建Openfireserver:

Openfire工具下载地址:http://www.igniterealtime.org/downloads/index.jsp

下载到本地点击安装。一步步进行就可以。网上的安装指导方法也非常多。我就參考了

站点:http://www.cnblogs.com/hoojo/archive/2012/05/17/2506769.html

第二步:下载及安装 Spark:

下载地址:http://www.igniterealtime.org/downloads/index.jsp,我下载的也是最新

Windows版本号Spark 2.7.5(spark_2_7_5.exe)。直接安装 就可以。这是一个相似QQ的聊天工具,

当你安装好Openfire后。就有一个帐号如admin,能够用这个帐号在Spark上登录。

第三步:下载asmack.jar包,主要是用于我们项目开发的jar包。网上搜索下,下载地址非常多。

完毕上面三步,基本上就能够開始我们的开发工作了。

首先新建 Android项目,导入刚刚下载好的smack.jar包。今天上午主要学习的是通过Android端连接server及注冊用户。

//主界面,主要是4个button:连接。注冊。登录,改动password
public class MainActivity extends ActionBarActivity implements OnClickListener {
private Button connect_server;
private Button register;
private Button login;
private Button update_pwd;
private Handler mHandler = new Handler() {
public void handleMessage(android.os.Message msg) {
if (msg.what == 1) {
Toast.makeText(MainActivity.this, "连接server成功。", Toast.LENGTH_SHORT).show();
}
else {
Toast.makeText(MainActivity.this, "连接server失败! ", Toast.LENGTH_SHORT).show();
}
};
}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initViewsAndEvents();
} private void initViewsAndEvents() {
this.connect_server = (Button) findViewById(R.id.connect_server);
this.register = (Button) findViewById(R.id.register);
this.login = (Button) findViewById(R.id.login);
this.update_pwd = (Button) findViewById(R.id.update_pwd);
this.connect_server.setOnClickListener(this);
this.register.setOnClickListener(this);
this.login.setOnClickListener(this);
this.update_pwd.setOnClickListener(this);
} @Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.connect_server:
new Thread(new Runnable() { @Override
public void run() {
boolean flag = isConnectServer();
Message msg = new Message();
if (flag) {
msg.what = 1;
}
mHandler.sendMessage(msg);
}
}).start();
break;
case R.id.register:
startActivity(new Intent(MainActivity.this, RegisterActivity.class));
break;
case R.id.login:
break;
case R.id.update_pwd:
break;
}
} private boolean isConnectServer() {
boolean isConnect = false;
// 第一步:初始化ConnectionConfiguration。參数是serverip,port号及server名称
ConnectionConfiguration config = new ConnectionConfiguration("主机ip地址", 5222, "server名称");
// 设置是否启用安全验证
config.setSelfSignedCertificateEnabled(false);
// 设置启用调试
config.setDebuggerEnabled(true);
// 同意自己主动连接
config.setReconnectionAllowed(true);
config.setSendPresence(true);
// 设置安全模式
config.setSecurityMode(ConnectionConfiguration.SecurityMode.disabled);
// 第二步:初始连接对象XMPPConnection
XMPPConnection conn = new XMPPConnection(config);
// 第三步:建立连接
try {
conn.connect();
// 连接成功返回true;
isConnect = true;
}
catch (XMPPException e) {
e.printStackTrace();
}
return isConnect;
}
}
/**
* 注冊或登录页面
* @description:
* @date 2016-2-20 上午10:36:27
*/
public class RegisterActivity extends ActionBarActivity implements OnClickListener {
private Button register;
private EditText edt_name;
private EditText edt_pwd;
private Handler mHandler = new Handler() {
public void handleMessage(android.os.Message msg) {
Toast.makeText(RegisterActivity.this, msg.obj.toString(), Toast.LENGTH_SHORT).show();
finish();
};
}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.register);
initViewsAndEvents();
} private void initViewsAndEvents() {
this.register = (Button) findViewById(R.id.register);
this.register.setOnClickListener(this);
this.edt_name = (EditText) findViewById(R.id.edt_name);
this.edt_pwd = (EditText) findViewById(R.id.edt_pwd);
} @Override
public void onClick(View v) {
if (v.getId() == R.id.register) {
new Thread(new Runnable() { @Override
public void run() {
String reslut = registerToServier(edt_name.getText().toString().trim(), edt_pwd.getText().toString().trim());
Message msg = new Message();
msg.obj = reslut;
mHandler.sendMessage(msg);
}
}).start(); }
} /**
* 注冊到server
* @description:
* @date 2016-2-20 上午10:41:09
*/
private String registerToServier(String name, String pwd) {
// 初始化ConnectionConfiguration,參数是serverip,port号及server名称
ConnectionConfiguration config = new ConnectionConfiguration("serverip地址", 5222, "server名称");
// 设置是否启用安全验证
config.setSelfSignedCertificateEnabled(false);
// 设置启用调试
config.setDebuggerEnabled(true);
// 同意自己主动连接
config.setReconnectionAllowed(true);
config.setSendPresence(true);
// 设置安全模式
config.setSecurityMode(ConnectionConfiguration.SecurityMode.disabled);
// 初始连接对象XMPPConnection
XMPPConnection connection = new XMPPConnection(config);
try {
connection.connect();
}
catch (XMPPException e) {
e.printStackTrace();
}
-上面连接server代码代码我又又一次写了一次。事实上应该进行封装,连接上server后。把connection对象保存起来-
if (connection == null) return "0";
// 初始化注冊Registration对象
Registration reg = new Registration();
reg.setType(IQ.Type.SET);
// 设置注冊到的server名称
reg.setTo("hx1401016");
// 设置username
reg.setUsername(name);
// 设置password
reg.setPassword(pwd);
// 这边addAttribute不能为空,否则出错。所以做个标志是android手机创建的吧!! !! !
reg.addAttribute("android", "geolo_createUser_android");
PacketFilter filter = new AndFilter(new PacketIDFilter(reg.getPacketID()), new PacketTypeFilter(IQ.class));
PacketCollector collector = connection.createPacketCollector(filter);
connection.sendPacket(reg);
IQ result = (IQ) collector.nextResult(SmackConfiguration.getPacketReplyTimeout());
// Stop queuing results
collector.cancel();// 停止请求results(是否成功的结果)
if (result == null) {
return "server没响应";
}
else if (result.getType() == IQ.Type.RESULT) {
return "注冊成功";
}
else { // if (result.getType() == IQ.Type.ERROR)
if (result.getError().toString().equalsIgnoreCase("conflict(409)")) {
return "注冊失败" + result.getError().toString();
}
else {
return "注冊失败" + result.getError().toString();
}
}
}
}
//主界面布局
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <Button
android:id="@+id/connect_server"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:text="与server连接" /> <Button
android:id="@+id/register"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:text="注冊" /> <Button
android:id="@+id/login"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:text="登录 " /> <Button
android:id="@+id/update_pwd"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:text="改动password" /> </LinearLayout>
//注冊页面布局
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <EditText
android:id="@+id/edt_name"
android:layout_width="match_parent"
android:layout_height="40dp"
android:hint="请输入username"
android:layout_margin="10dp"/> <EditText
android:id="@+id/edt_pwd"
android:layout_width="match_parent"
android:layout_height="40dp"
android:hint="请输入password"
android:layout_margin="10dp" /> <Button
android:id="@+id/register"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:text="注冊" />
</LinearLayout>

Openfire配置成功后,后台图片展示:



代码中注冊成功的用户信息:



接下来来继续学习登录,改动password等。

Android基于XMPP Smack及Openfire学习笔记(1)的更多相关文章

  1. Android基于XMPP Smack openfire 开发的聊天室

    Android基于XMPP Smack openfire 开发的聊天室(一)[会议服务.聊天室列表.加入] http://blog.csdn.net/lnb333666/article/details ...

  2. Android基于XMPP Smack Openfire下学习开发IM(六)总结

    不管学习什么都应该总结 这里我把关于Xmpp的一些方法整理到一个工具类中了 我就分享给大家 XmppConnection.java package com.techrare.utils; import ...

  3. Android基于XMPP Smack Openfire下学习开发IM(一)实现用户注册、登录、修改密码和注销等

    http://blog.csdn.net/h7870181/article/details/8653865 以前学习过用Scoket 建立聊天,简单的建立聊天是没问题的,但如果要实现多人复杂的聊天,后 ...

  4. Android基于XMPP Smack Openfire下学习开发IM(五)连接断开重连

    学习过程中大家都碰到过连接被断开的问题给困扰吧,下面教大家如何做到连接断开后,重新连接 首先要创建连接监听器,用来监听连接状态,这里我写了一个类 继承了ConnectionListener,重写了里面 ...

  5. 基于XMPP实现的Openfire的配置安装+Android客户端的实现

    最近在整理一些这方面的资料,闲话少说,咱还是直奔主题吧 :) 一.基于xmpp实现的openfire的配置安装 1. 下载最新的openfire安装文件 官方下载站点: http://www.igni ...

  6. 基于XMPP实现的Openfire的配置安装+Android客户端的实现[转]

    最近在整理一些这方面的资料,闲话少说,咱还是直奔主题吧 :) http://blog.csdn.net/sk719887916/article/details/40541163 https://git ...

  7. 基于XMPP协议(openfire服务器)的消息推送实现

    转自:http://blog.csdn.net/nomousewch/article/details/8088277 最近好像有不少朋友关注Android客户端消息推送的实现,我在之前的项目中用到过J ...

  8. Android基于XMPP的即时通讯2-文件传输

    本文是在上一篇博文Android基于XMPP的即时通讯1-基本对话的基础上,添加新的功能,文件传输 1.初始化文件传输管理类 public static FileTransferManager get ...

  9. Android M Permission 运行时权限 学习笔记

    Android M Permission 运行时权限 学习笔记 从Android 6.0开始, 用户需要在运行时请求权限, 本文对运行时权限的申请和处理进行介绍, 并讨论了使用运行时权限时新老版本的一 ...

随机推荐

  1. Django是什么

    Django是什么 Django是什么? 是基于python语言的优秀的web开发框架.很多有名的网站比如youtube就是用django开发的. Python写的开源Web应用框架, 快速搭建blo ...

  2. MinGW安装和使用基础教程

    MinGW全称Minimalist GNU For Windows,是个精简的Windows平台C/C++.ADA及Fortran编译器,相比Cygwin而言,体积要小很多,使用较为方便.MinGW提 ...

  3. BMP图片格式模型

    BMP BMP(全称Bitmap)是Window操作系统中的标准图像文件格式 可以分成两类:设备相关位图(DDB)和设备无关位图(DIB),使用非常广. 它采用位映射存储格式,除了图像深度可选以外,不 ...

  4. BZOJ 2115 DFS+高斯消元

    思路: 先搞出来所有的环的抑或值 随便求一条1~n的路径异或和 gauss消元找异或和最大 贪心取max即可 //By SiriusRen #include <cstdio> #inclu ...

  5. 《剑指offer》链表中倒数第k个结点

    一.题目描述 输入一个链表,输出该链表中倒数第k个结点. 二.输入描述 一个链表 三.输出描述 链表的倒数第k个结点 四.牛客网提供的框架 /* struct ListNode { int val; ...

  6. PyCharm 2017 Mac 免注册版破解安装说明

    PyCharm 2017 Mac 免注册版破解安装说明 下载完成安装包后,双击打开,将左侧拖拽至右侧应用程序,默认安装. 打开软件,在License server address中填入[http:// ...

  7. Linux 运维笔试题(一)

    试题:   1.说出下列服务对应的端口或者端口对应的服务 21  23  25  873  161  111  110  53  123  2049   2.文件atime,ctime,mtime的区 ...

  8. 运维派 企业面试题3 为上题中的 "十个随机字母_test.html" 文件 更名

    Linux运维必会的实战编程笔试题(19题) 企业面试题3 #将试题2中创建的文件名uopiyhgawe_test.html# test-->修改为omg,html-->HTML 方法一: ...

  9. JS文字特效:彩色滚动变幻效果,只适合少量的文字。(过多对页面有影响)

    JS代码如下: 代码具体是在哪里的我不知道但是我的有道云上有.如有哪位朋友知道,还望联系下,添加出处. <div id="chakhsu"></div> & ...

  10. 运行npm start vue.js项目 出现 npm ERR! missing script: start 错误

    npm ERR! missing script: start 错误 有可能缺少依赖包,运行nmp install安装依赖(一般都依赖很多包,过程有点慢),安装完后发现多一个 node_modules文 ...