首先iOS与mac端用的框架是:https://github.com/ckrey/MQTT-Client-Framework

使用CocoaPods导入

pod 'MQTTClient/Websocket' , '~> 0.6.9'

然后服务端用的是Apache Apollo

http://activemq.apache.org/apollo/index.html

然后还需要一个JDK,这里面需要一个关于JAVA_HOME的配置。当时稍微百度了一下。

首先是服务端的配置,安装好之后直接run,服务端就起来了,我们可以看到有一系列的ip地址与端口号。

我们用与MQTT协议与服务器交互的是用TCP链接的ip与端口。

客户端上我们首先打开pod创建的工作空间

需要进行MQTT通讯的类的头文件导入

#import "MQTTClient.h"

同时使该类遵循协议

<MQTTSessionDelegate>

需要进行MQTT的实现文件中

//创建一个传输类型的实例

MQTTCFSocketTransport *transport = [[MQTTCFSocketTransport alloc] init];

transport.host = @"localhost";//设置传输的主机,这里我是用的是本地服务器,当然也可以使用远程的ip地址。

transport.port = 61613;//传输主机的监听端口

//创建一个任务

MQTTSession *session = [[MQTTSession alloc] init];

session.transport = transport;//设置任务的传输类型

session.delegate = self;//设置任务的代理为当前类

session.userName = @"admin";//设置任务连接使用的用户名

session.password = @"password";//设置任务连接使用的密码

//连接

[session connectWithConnectHandler:^(NSError *error) {

//以下部分是连接完成后执行的block

if (!error){

    //以下部分是订阅一个话题

[session subscribeToTopic:@"topic" atLevel:2 subscribeHandler:^(NSError *error, NSArray<NSNumber *> *gQoss){

if (error) {

NSLog(@"Subscription failed %@", error.localizedDescription);

} else {

NSLog(@"Subscription sucessfull! Granted Qos: %@", gQoss);

}

}];

}else{

NSLog(@"error:%@",error);

}

}];

//设置任务代理并连接成功之后,收到订阅的话题信息会执行以下

- (void)newMessage:(MQTTSession *)session

data:(NSData *)data

onTopic:(NSString *)topic

qos:(MQTTQosLevel)qos

retained:(BOOL)retained

mid:(unsigned int)mid{

NSString *dataStr = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];

NSLog(@"数据:%@",dataStr);

NSLog(@"话题:%@",topic);

}

//若要发送消息

NSString *str = @"Hello";

NSData *data = [str dataUsingEncoding:NSUTF8StringEncoding];

if ([session publishAndWaitData:data

onTopic:@"topic"

retain:NO

qos:MQTTQosLevelAtLeastOnce]){

    //这部分是如果发送消息成功了,可以在这里写发送成功之后的操作

}

然后我的测试是mac一个小窗口,一个iOS的模拟机,都可以成功发送或者收到订阅的信息。

ObjectiveC-MQTT初次接触的更多相关文章

  1. OC 初次接触

    初次接触ObjC时,会发现许多和其它语言不同的地方,会看到很多的+,- ,[ ,] ,@, NS等符号,这些符号在以后的编程中将经常看到,这部分内容在第二节中介绍.先熟悉一下ObjC的代码: #imp ...

  2. 初次接触json...

    这两天发现很多网站显示图片版块都用了瀑布流模式布局的:随着页面滚动条向下滚动,这种布局还会不断加载数据并附加至当前尾部.身为一个菜鸟级的程序员,而且以后可能会经常与网站打交道,我觉得我还是很有必要去尝 ...

  3. 初次接触GWT,知识点总括

    初次接触GWT,知识点概括 前言 本人最近开始研究 GWT(Google Web Toolkit) ,现将个人的一点心得贴出来,希望对刚开始接触 GWT的程序员们有所帮助,也欢迎讨论,共同进步. 先说 ...

  4. [Docker]初次接触

    Docker 初次接触 近期看了不少docker介绍性文章,也听了不少公开课,于是今天去官网逛了逛,发现了一个交互式的小教程于是决定跟着学习下. 仅仅是把认为重点的知识记录下来,不是非常系统的学习和笔 ...

  5. 初次接触:DirectDraw

    第六章 初次接触:DirectDraw 本章,你将初次接触DirectX中最重要的组件:DirectDraw.DirectDraw可能是DirectX中最强大的技术,因为其贯穿着2D图形绘制同时其帧缓 ...

  6. 初次接触scrapy框架

    初次接触这个框架,先订个小目标,抓取QQ首页,然后存入记事本. 安装框架(http://scrapy-chs.readthedocs.io/zh_CN/0.24/intro/install.html) ...

  7. javaweb中的乱码问题(初次接触时写)

    javaweb中的乱码问题 在初次接触javaweb中就遇到了乱码问题,下面是我遇到这些问题的解决办法 1. 页面乱码(jsp) 1. 在页面最前方加上 <%@ page language=&q ...

  8. 初次接触Java

    今天初次接触Eclipse,学着用他来建立java工程,话不多说,来看看今天的成果! 熟悉自己手中的开发工具,热热身 刚上手别慌,有问题找度娘 刚刚拿到这个软件的安装包我是一脸懵逼的,因为是从官网下载 ...

  9. -1.记libgdx初次接触

    学习一门技术最难的是开发环境变量配置和工具配置,以下为我初次接触libgdx时遇到的问题 几个难点记录下 gradle 直接用下到本地,然后放到d盘,链接到就行(gradle-wrapper.prop ...

  10. tensorflow初次接触记录,我用python写的tensorflow第一个模型

    tensorflow初次接触记录,我用python写的tensorflow第一个模型 刚用python写的tensorflow机器学习代码,训练60000张手写文字图片,多层神经网络学习拟合17000 ...

随机推荐

  1. Vim插件管理器Vundle使用

    参考地址:http://www.linuxidc.com/Linux/2012-12/75684.htm Vundle(Vim bundle) 是一个vim的插件管理器. 其Github地址为: ht ...

  2. svn 版本控制

    首先来下载和搭建SVN服务器. Subversion已经迁移到apache网站上了,下载地址: http://subversion.apache.org/packages.html windows操作 ...

  3. ime-mode

    2016-08-18 ime-mode 用户输入法控制,主要是防止用户输入文本符号等(比如电话号码输入时) (设定值) auto・・・和没设定一样 active・・・激活本地输入法(如中文),用户可以 ...

  4. 自动生成build.xml文件

    使用Eclipse 自动生成 Ant的Build.xml 配置文件,选择要生成Build.xml文件的项目,鼠标右键, Export-> General -> Ant Buildfiles ...

  5. css 表格

    1.给元素的display属性添加为以下值 table : <table> table-caption :<caption> table-cell : <td> t ...

  6. tensorflow版的bvlc模型

    研究相关的图片分类,偶然看到bvlc模型,但是没有tensorflow版本的,所以将caffe版本的改成了tensorflow的: 关于模型这个图: 下面贴出通用模板: from __future__ ...

  7. C plus plus study note (one)

    What is an object ? Object = Entity ; Object may be -- visible or -- invisible Object is variable in ...

  8. 【译】Learn ES2015——箭头函数

    原文:https://babeljs.io/learn-es2015/ 理解也许有偏差,欢迎指正 箭头函数 不同于函数,箭头函数和包裹它的代码拥有同一个this.如果一个箭头函数在一个function ...

  9. SAP连接电脑串口读数(电子称,磅等数据读取)

    这是几年前做的了,一直都不想分享出来,后来想想为了能够给大家点想法,献出来了... 这是一个电脑读称的方法,一般用COMM口连接的电子设备都可参考. 如果是对串口参数不确定的,可以网上找个串口测试工具 ...

  10. Javascript理解this对象

    this是函数运行时自动生成的一个内部对象,只能在函数内部使用,但总指向调用它的对象. 通过以下几个例子加深对this的理解. (1)作为函数调用 var name = 'Jenny'; functi ...