首先物联网协议mqtt协议是基于tcp/ip协议的,使用了官方的mqttclient框架

/*
*初始化mqttclient
*/
private void init() {
try {
//MQTT的连接设置
options = new MqttConnectOptions();
//host为主机名,test为clientid即连接MQTT的客户端ID,一般以客户端唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存
client = new MqttClient(new Ip().host, username,
new MemoryPersistence());
//设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,这里设置为true表示每次连接到服务器都以新的身份连接
options.setCleanSession(false);
//options.setWill(myTopic,null,2,false); //设置连接的用户名
options.setUserName(login_token);
//设置连接的密码
options.setPassword(passWord.toCharArray());
// 设置超时时间 单位为秒
options.setConnectionTimeout(10);
// 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
options.setKeepAliveInterval(60);
//设置回调
client.setCallback(new MqttCallback() {
@Override
public void connectionLost(Throwable cause) {
//连接丢失后,一般在这里面进行重连
System.out.println("connectionLost----------"); } @Override
public void deliveryComplete(IMqttDeliveryToken token) {
//publish后会执行到这里
System.out.println("deliveryComplete---------"
+ token.isComplete());
}
@Override
public void messageArrived(String topicName, MqttMessage message)
throws Exception {
byte[] message1 = message.getPayload();
// subscribe后得到的消息会执行到这里面
System.out.println("messageArrived----------" + message1[0] + Arrays.toString(message1));
System.out.println(message1[0] == 5);
String id = new String(subBytes(message1, 1, 16), "UTF-8"); System.out.print("mqtt收到的id" + id);
DeviceList device = getBookById(id);
System.out.print("device" + device.getName());
String name = device.getName();
String gName = device.getgName();
String type = device.getType();
System.out.print("名字为" + name + gName);
/**
* 使用handler发送matt接收的消息,格式为二进制数据
* */ Message msg = new Message();
msg.what = 1;
if (message1[0] == 1) {
// msg.obj = name + "设备心跳";
// handler.sendMessage(msg);
return;
}
if (message1[0] == 2) {
msg.obj = gName + "" + name + "报警";
msg.arg1 = Integer.parseInt(type);
handler.sendMessage(msg);
return;
}
if (message1[0] == 3) {
msg.obj = gName + "" + name + "上线";
handler.sendMessage(msg);
return;
}
if (message1[0] == 4) {
msg.obj = gName + "" + name + "离线";
handler.sendMessage(msg);
return;
}
if (message1[0] == 5) {
if (message1[17] == 0) {
msg.obj = gName + "" + name + "关门";
} else {
msg.obj = gName + "" + name + "开门";
} handler.sendMessage(msg);
return;
}
if (message1[0] == 20 && message1[17] > 0 && message1[17] < 20) { msg.obj = name + "电池电量: " + message1[17] + "%";
handler.sendMessage(msg);
System.out.println("电池:" + name + "电池电量: " + message1[17] + "%");
return;
}
if (message1[17] > 0) {
SharedPreferences sp = getActivity().getSharedPreferences(id, getActivity().MODE_PRIVATE);
// 获得sp的编辑器
SharedPreferences.Editor ed = sp.edit();
// 以键值对的显示将用户名和密码保存到sp中
ed.putString("battery", String.valueOf(message1[17]));
// 提交用户名和密码
ed.commit();
}
}
});
} catch (Exception e) {
e.printStackTrace();
}
} public byte[] subBytes(byte[] src, int begin, int count) {
byte[] bs = new byte[count];
System.arraycopy(src, begin, bs, 0, count);
return bs;
} //根据id拿到属性为id的Book对象。
public static DeviceList getBookById(String id) {
DeviceList book = new DeviceList();
book.setId(id);//设置传入的id值
//books.indexOf()根据id比较对象是否相等
return deviceList1.get(deviceList1.indexOf(book));
//返回关联id的Book对象。
} private void connect() {
new Thread(new Runnable() { @Override
public void run() {
try {
client.connect(options);
Message msg = new Message();
msg.what = 2;
handler.sendMessage(msg);
} catch (Exception e) {
e.printStackTrace();
Message msg = new Message();
msg.what = 3;
handler.sendMessage(msg);
}
}
}).start();
} protected boolean onKeyDown(int keyCode, KeyEvent event) {
if (client != null && keyCode == KeyEvent.KEYCODE_BACK) {
try {
client.disconnect();
} catch (Exception e) {
e.printStackTrace();
}
}
return super.getActivity().onKeyDown(keyCode, event);
} @Override
public void onDestroy() {
super.onDestroy();
try {
scheduler.shutdown();
client.disconnect();
} catch (MqttException e) {
e.printStackTrace();
}
} private void startReconnect() {
scheduler = Executors.newSingleThreadScheduledExecutor();
scheduler.scheduleAtFixedRate(new Runnable() { @Override
public void run() {
if (!client.isConnected()) {
connect();
}
}
}, 0 * 1000, 10 * 1000, TimeUnit.MILLISECONDS);
}
其次使用handlermessage接收消息,并已notifacation的形式展示在通知栏页面
 handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (msg.what == 1) {
NotificationManager manager = (NotificationManager) getActivity().getSystemService(Context.NOTIFICATION_SERVICE);
Notification myNotify = new Notification();
myNotify.icon = R.drawable.logo;
myNotify.tickerText = "新消息";
myNotify.when = System.currentTimeMillis();
//使用默认的声音
myNotify.defaults |= Notification.DEFAULT_SOUND; //使用默认的震动
myNotify.defaults |= Notification.DEFAULT_VIBRATE; //使用默认的声音、振动、闪光
myNotify.defaults = Notification.DEFAULT_ALL;
// myNotify.flags=Notification.FLAG_AUTO_CANCEL;
// myNotify.flags = Notification.FLAG_NO_CLEAR;// 不能够自动清除
RemoteViews rv = new RemoteViews(getActivity().getPackageName(),
R.layout.activity_notification1);
rv.setTextViewText(R.id.tv_desc, (String) msg.obj);
myNotify.contentView = rv;
Intent intent = new Intent(getActivity(), MainActivity.class);
// intent.addCategory(Intent.CATEGORY_LAUNCHER);
// intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS);
android.app.PendingIntent contentIntent = android.app.PendingIntent.getActivity(getActivity(), 0,
intent, 0);
myNotify.contentIntent = contentIntent;
manager.notify(i1++, myNotify);
PowerManager pm = (PowerManager) getActivity().getSystemService(Context.POWER_SERVICE);
PowerManager.WakeLock wakeLock = pm.newWakeLock(PowerManager.ACQUIRE_CAUSES_WAKEUP |
PowerManager.SCREEN_DIM_WAKE_LOCK, "target");
boolean screen = pm.isScreenOn();
if (!screen) {//如果灭屏
wakeLock.acquire();
wakeLock.release();
}
refresh();
} else if (msg.what == 2) {
System.out.println("连接成功");
System.out.print("连接成功大小" + listDatas2.size());
try {
client.subscribe(myTopic, 1);
client.subscribe(myTopic1, 1);
} catch (MqttException e) {
e.printStackTrace();
}
} else if (msg.what == 3) {
//Toast.makeText(MainActivity.this, "连接失败,系统正在重连", Toast.LENGTH_SHORT).show();
System.out.println("连接失败,系统正在重连");
}
}
};

安卓开发之mqtt协议的更多相关文章

  1. android开发之http协议

    http协议学习系列 1. 基础概念篇 1.1 介绍 HTTP是Hyper Text Transfer Protocol(超文本传输协议)的缩写.它的发展是万维网协会(World Wide Web C ...

  2. 安卓开发之Toolbar

    根据官网的教程,发现实现与预期不一致,查看相关资料自己整理了一下(官网开发文档:https://developer.android.com/training/appbar/setting-up.htm ...

  3. 安卓开发之ListAdapter(二)

    今天我们来学习一下ArrayAdapter: ArrayAdapter是安卓中最简单的适配器.使用ArrayAdapter(数组适配器),需要把数据源存 放至数组里面来显示. •构造函数: publi ...

  4. 安卓开发之UIwebview

    web view在安卓开发中是比较常见的UI,像微信的新闻模块就采用了这个,他的作用越来越广,下面我把以前做的贴了出来,如果有更好的办法,希望大神不吝赐教哈,嘿嘿,纯代码来了: java代码 publ ...

  5. 【转】Unity3D开发之Http协议网络通信

    之前unity3d项目要做跟服务器通信的模块,然后服务器那边的协议是基于http的Jsonrpc通信方式一开始,用C#的本身类HttpWebRequest来提交请求,很快就在电脑上面成功了,代码也很简 ...

  6. IOS开发之NSObject协议类方法说明

    oc中NSObject类是所有类的基类,所有类都要继承自它,那么它的方法就显得特别重要,因为所有类都会有这些基本的方法. 看看oc的源码中NSObject是这样定义的: @interface NSOb ...

  7. phonegap移动开发之jsonp协议

    最近我一直在学习android开发.并且做了几个小软件,我会在百度网盘和二维码的形式分享出去!源码会分享到github上.下面我还是主要来说说jsonp协议吧.可能许多初学者会遇到许多跟我一样的问题. ...

  8. Web开发之HTTP协议

    HTTP响应消息 一个HTTP响应代表服务器向客户端回送的数据. 一个完整的HTTP响应包括如下内容: 一个状态行.若干消息头.以及响应正文,其中的一些消息头和正文都是可选的,消息头和正文内容之间要用 ...

  9. 安卓开发之activity详解(sumzom)

    app中,一个activity通常是指的一个单独的屏幕,相当于网站里面的一个网页,它是对用户可见的,它上面可以显示一些控件,并且可以监听处理用户的时间做出响应. 那么activity之间如何进行通信呢 ...

随机推荐

  1. Windows环境下多线程编程原理与应用读书笔记(2)————面向对象技术

    面向对象技术是学C++需要重点掌握的知识,因为我觉得自己的基础还是比较可以,这一章节的内容就只是粗略的读了一遍,在此就不做过多的笔记.

  2. Increasing Speed Limits

    Increasing Speed Limits Time Limit: 2000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...

  3. Grunt打包seajs项目

    在使用seajs时,常常将若干脚本分为多次require进来,这样开发中比较方便,但是,会增加http请求次数,在生产环境中需要进行打包合并.压缩等操作. 以Grunt构建工具为例,对一个seajs项 ...

  4. HTML学习笔记 css定位(静态,相对,固定,绝对布局)偏移案例 第十二节 (原创) 参考使用表

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. HTML学习笔记 基础标签及css引用案例 第一节 (原创)参考使用表

    <!DOCTYPE html><!--头文件 不是标签 也没有结束,这是声明该文件为HTML5--><html lang="en"><!- ...

  6. 我眼中的WebViewJavascriptBridge

    周六阳光明媚的早晨,非常适合整理和分享一些以前玩过的东西.曾经的工作中参与过一段时间iOS开发,在开发中有个小小的框架让我非常深刻,就是WebViewJavascriptBridge,用于原生控件与前 ...

  7. hiero_v2.0的下载安装和使用

    程序地址:http://www.n4te.com/hiero/hiero.jnlp http://slick.cokeandcode.com/demos/hiero.jnlp(目测该网址需翻*墙才能进 ...

  8. php 常用 常量集合

    DIRECTORY_SEPARATOR 常量 DIRECTORY_SEPARATOR  目录分割符

  9. 三:动态SQL

    :动态SQL 1.使用动态sql完成多条件查询 If:利用if实现简单的条件选择 Choose(when,otherwise):相当于java中的switch语句,通常与whenhe otherwis ...

  10. python进阶------进程线程(五)

    Python中的IO模型 同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别 ...