Android基于XMPP Smack及Openfire学习笔记(3)

2024-04-23 01:18

本文主要是介绍Android基于XMPP Smack及Openfire学习笔记(3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在前面两篇文章Android基于XMPP Smack及Openfire学习笔记(1)及Android基于XMPP Smack及Openfire学习笔记(2)中,分别讲了用户注册,登录,修改密码等。代码凌乱,所以参考网上资料,就写了个工具类。方便以后直接使用。继续学习中…..

/*** Android XMPP Openfire操作工具类* 注册,登录,修改密码及更改用户在线状态,可以直接调用对应方法* 比如注册就调用:XMPPConnectTool.getInstance().registerToServer();* @description:* @date 2016-2-20 下午2:43:29*/
public class XMPPConnectTool {private static final String HOST_IP = "127.0.0.1";// 服务器ipprivate static final int PORT = 5222;private static final String SERVER_NAME = "hxxxx";// 服务器名称,完成openfire安装 ,后台 可以查看到private static XMPPConnectTool instance;private XMPPConnection mXmppConnection = null;private XMPPConnectTool() {}// 单例模式public static XMPPConnectTool getInstance() {if (instance == null) {instance = new XMPPConnectTool();}return instance;}// 获取XMPPConnection对象public XMPPConnection getConnection() {if (mXmppConnection == null) {initConnection();}return mXmppConnection;}/*** 初始化建立链接* @description:* @author ldm* @date 2016-2-20 下午2:53:50*/public boolean initConnection() {try {if (null == mXmppConnection || !mXmppConnection.isAuthenticated()) {// 配置ConnectionConfigurationConnectionConfiguration config = new ConnectionConfiguration(HOST_IP, PORT, SERVER_NAME);// 设置可以重连config.setReconnectionAllowed(true);config.setSecurityMode(ConnectionConfiguration.SecurityMode.disabled);// 设离线,可以取离线消息config.setSendPresence(true);// 是否启用安全验证config.setSASLAuthenticationEnabled(false);config.setTruststorePath("/system/etc/security/cacerts.bks");config.setTruststorePassword("changeit");config.setTruststoreType("bks");mXmppConnection = new XMPPConnection(config);// 连接到服务器mXmppConnection.connect();// 配置各种Provider,如果不配置,则会无法解析数据configureProviderManager(ProviderManager.getInstance());return true;}}catch (XMPPException e) {mXmppConnection = null;e.printStackTrace();}return false;}/*** 配置ProviderManager* 这些也是网上找的,很多都还不知道是啥东东,慢慢学习* @description:* @author ldm* @date 2016-2-20 下午3:15:17*/public void configureProviderManager(ProviderManager pm) {// Private Data Storagepm.addIQProvider("query", "jabber:iq:private", new PrivateDataManager.PrivateDataIQProvider());// Timetry {pm.addIQProvider("query", "jabber:iq:time", Class.forName("org.jivesoftware.smackx.packet.Time"));}catch (ClassNotFoundException e) {Log.w("TestClient", "Can't load class for org.jivesoftware.smackx.packet.Time");}// Roster Exchangepm.addExtensionProvider("x", "jabber:x:roster", new RosterExchangeProvider());// Message Eventspm.addExtensionProvider("x", "jabber:x:event", new MessageEventProvider());// Chat Statepm.addExtensionProvider("active", "http://jabber.org/protocol/chatstates", new ChatStateExtension.Provider());pm.addExtensionProvider("composing", "http://jabber.org/protocol/chatstates", new ChatStateExtension.Provider());pm.addExtensionProvider("paused", "http://jabber.org/protocol/chatstates", new ChatStateExtension.Provider());pm.addExtensionProvider("inactive", "http://jabber.org/protocol/chatstates", new ChatStateExtension.Provider());pm.addExtensionProvider("gone", "http://jabber.org/protocol/chatstates", new ChatStateExtension.Provider());// XHTMLpm.addExtensionProvider("html", "http://jabber.org/protocol/xhtml-im", new XHTMLExtensionProvider());// Group Chat Invitationspm.addExtensionProvider("x", "jabber:x:conference", new GroupChatInvitation.Provider());// Service Discovery # Itemspm.addIQProvider("query", "http://jabber.org/protocol/disco#items", new DiscoverItemsProvider());// Service Discovery # Infopm.addIQProvider("query", "http://jabber.org/protocol/disco#info", new DiscoverInfoProvider());// Data Formspm.addExtensionProvider("x", "jabber:x:data", new DataFormProvider());// MUC Userpm.addExtensionProvider("x", "http://jabber.org/protocol/muc#user", new MUCUserProvider());// MUC Adminpm.addIQProvider("query", "http://jabber.org/protocol/muc#admin", new MUCAdminProvider());// MUC Ownerpm.addIQProvider("query", "http://jabber.org/protocol/muc#owner", new MUCOwnerProvider());// Delayed Deliverypm.addExtensionProvider("x", "jabber:x:delay", new DelayInformationProvider());// Versiontry {pm.addIQProvider("query", "jabber:iq:version", Class.forName("org.jivesoftware.smackx.packet.Version"));}catch (ClassNotFoundException e) {e.printStackTrace();}// VCardpm.addIQProvider("vCard", "vcard-temp", new VCardProvider());// Offline Message Requestspm.addIQProvider("offline", "http://jabber.org/protocol/offline", new OfflineMessageRequest.Provider());// Offline Message Indicatorpm.addExtensionProvider("offline", "http://jabber.org/protocol/offline", new OfflineMessageInfo.Provider());// Last Activitypm.addIQProvider("query", "jabber:iq:last", new LastActivity.Provider());// User Searchpm.addIQProvider("query", "jabber:iq:search", new UserSearch.Provider());// SharedGroupsInfopm.addIQProvider("sharedgroup", "http://www.jivesoftware.org/protocol/sharedgroup", new SharedGroupsInfo.Provider());// JEP-33: Extended Stanza Addressingpm.addExtensionProvider("addresses", "http://jabber.org/protocol/address", new MultipleAddressesProvider());// FileTransferpm.addIQProvider("si", "http://jabber.org/protocol/si", new StreamInitiationProvider());pm.addIQProvider("query", "http://jabber.org/protocol/bytestreams", new BytestreamsProvider());// Privacypm.addIQProvider("query", "jabber:iq:privacy", new PrivacyProvider());pm.addIQProvider("command", "http://jabber.org/protocol/commands", new AdHocCommandDataProvider());pm.addExtensionProvider("malformed-action", "http://jabber.org/protocol/commands", new AdHocCommandDataProvider.MalformedActionError());pm.addExtensionProvider("bad-locale", "http://jabber.org/protocol/commands", new AdHocCommandDataProvider.BadLocaleError());pm.addExtensionProvider("bad-payload", "http://jabber.org/protocol/commands", new AdHocCommandDataProvider.BadPayloadError());pm.addExtensionProvider("bad-sessionid", "http://jabber.org/protocol/commands", new AdHocCommandDataProvider.BadSessionIDError());pm.addExtensionProvider("session-expired", "http://jabber.org/protocol/commands", new AdHocCommandDataProvider.SessionExpiredError());}/*** 断开连接* @description:* @author ldm* @date 2016-2-20 下午3:18:33*/public void closeXmpp() {if (mXmppConnection != null) {// 启用disconnect();if (mXmppConnection.isConnected()) mXmppConnection.disconnect();mXmppConnection = null;}}/*** 登录操作* @description:* @author ldm* @date 2016-2-20 下午3:19:41*/public void loginToServer(String name, String pwd) {try {if (getConnection() == null) return;// 进行登录操作:传入用户名,密码getConnection().login(name, pwd);// 登录成功更改在线状态Presence presence = new Presence(Presence.Type.available);getConnection().sendPacket(presence);}catch (XMPPException xe) {xe.printStackTrace();}}/*** 注册* 注册返回说明:* 1、注册成功 0、服务器没有返回结果2、这个账号已经存在3、注册失败* @description:* @date 2016-2-20 下午3:24:08*/public String registerToServer(String name, String pwd) {if (getConnection() == null) return "0";Registration reg = new Registration();reg.setUsername(name);reg.setPassword(pwd);reg.setType(IQ.Type.SET);reg.setTo(getConnection().getServiceName());// 这边addAttribute不能为空,否则出错reg.addAttribute("android", "geolo_createUser_android");PacketFilter filter = new AndFilter(new PacketIDFilter(reg.getPacketID()), new PacketTypeFilter(IQ.class));PacketCollector collector = getConnection().createPacketCollector(filter);getConnection().sendPacket(reg);IQ result = (IQ) collector.nextResult(SmackConfiguration.getPacketReplyTimeout());collector.cancel();if (result == null) {return "0";}else if (result.getType() == IQ.Type.RESULT) {return "1";}else {if (result.getError().toString().equalsIgnoreCase("conflict(409)")) {return "2";}else {return "3";}}}/*** 用户登录 成功后,设置用户在线状态* @description:* @date 2016-2-20 下午3:26:27*/public void setUserState(int code) {XMPPConnection con = getConnection();if (con == null) return;Presence presence = null;switch (code) {case 0:presence = new Presence(Presence.Type.available);// 设置在线con.sendPacket(presence);break;case 1:presence = new Presence(Presence.Type.available);presence.setMode(Presence.Mode.chat);// 设置Q我吧con.sendPacket(presence);break;case 2:presence = new Presence(Presence.Type.available);presence.setMode(Presence.Mode.dnd);// 设置忙碌con.sendPacket(presence);break;case 3:presence = new Presence(Presence.Type.available);presence.setMode(Presence.Mode.away);// 设置离开"con.sendPacket(presence);break;case 4:Roster roster = con.getRoster();Collection<RosterEntry> entries = roster.getEntries();for (RosterEntry entry : entries) {presence = new Presence(Presence.Type.unavailable);presence.setPacketID(Packet.ID_NOT_AVAILABLE);presence.setFrom(con.getUser());presence.setTo(entry.getUser());con.sendPacket(presence);Log.v("state", presence.toXML());}// 向同一用户的其他客户端发送隐身状态presence = new Presence(Presence.Type.unavailable);presence.setPacketID(Packet.ID_NOT_AVAILABLE);presence.setFrom(con.getUser());presence.setTo(StringUtils.parseBareAddress(con.getUser()));con.sendPacket(presence);break;case 5:presence = new Presence(Presence.Type.unavailable);con.sendPacket(presence);// 设置离线break;default:break;}}/*** 修改密码* @description:* @date 2016-2-20 下午3:29:19*/public boolean changePwd(String pwd) {if (getConnection() == null) return false;try {getConnection().getAccountManager().changePassword(pwd);return true;}catch (XMPPException e) {return false;}}}

这篇关于Android基于XMPP Smack及Openfire学习笔记(3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/927393

相关文章

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06