MQTT学习(七)--使用MQTTNet+ASP.NET Core创建MQTT服务器(broker)

经过漫长的等待,MQTT专题终于等到了第七篇,本次将在ASP.NET Core框架下利用MQTTnet创建自有服务器。


由于最近刚开始接触ASP.NET Core,很多具体的用法还没有研究透彻,所以本篇重点在核心的几段代码,示例参考了MQTTnet官方源码。

本示例将融合ASP.NET Core WebAPI,以便在API接口调用中实现消息推送。

1.创建项目并引用MQTTnet

在这里插入图片描述
在VS2017中新建ASP.NET Core Web应用程序,打开NuGet管理器,搜索并安装MQTTnet.AspNetCore。

2.实现MQTT服务器功能

2.1.启动配置项-Startup.cs
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);

            #region MQTT配置
            string hostIp = Configuration["MqttOption:HostIp"];//IP地址
            int hostPort = int.Parse(Configuration["MqttOption:HostPort"]);//端口号
            int timeout = int.Parse(Configuration["MqttOption:Timeout"]);//超时时间
            string username = Configuration["MqttOption:UserName"];//用户名
            string password = Configuration["MqttOption:Password"];//密码

            //构建配置项
            var optionBuilder = new MqttServerOptionsBuilder()
                .WithDefaultEndpointBoundIPAddress(System.Net.IPAddress.Parse(hostIp))
                .WithDefaultEndpointPort(hostPort)
                .WithDefaultCommunicationTimeout(TimeSpan.FromMilliseconds(timeout))
                .WithConnectionValidator(t =>
                {
                    if (t.Username != username || t.Password != password)
                    {
                        t.ReturnCode = MqttConnectReturnCode.ConnectionRefusedBadUsernameOrPassword;
                    }
                    t.ReturnCode = MqttConnectReturnCode.ConnectionAccepted;
                });
            var option = optionBuilder.Build();

            //服务注入
            services
                .AddHostedMqttServer(option)
                .AddMqttConnectionHandler()
                .AddConnections();
            #endregion

        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseMvc();


            app.UseConnections(c => c.MapConnectionHandler<MqttConnectionHandler>("/data", options =>
            {
                options.WebSockets.SubProtocolSelector = MQTTnet.AspNetCore.ApplicationBuilderExtensions.SelectSubProtocol;
            }));

            app.UseMqttEndpoint("/data");
            //MQTT声明周期事件
            app.UseMqttServer(server =>
            {
                //服务启动事件
                server.Started += async (sender, args) =>
                {
                    var msg = new MqttApplicationMessageBuilder().WithPayload("welcome to mqtt").WithTopic("start");
                    while (true)
                    {
                        try
                        {
                            await server.PublishAsync(msg.Build());
                            msg.WithPayload("you are welcome to mqtt");
                        }
                        catch (Exception e)
                        {
                            Console.WriteLine(e);
                        }
                        finally
                        {
                            await Task.Delay(TimeSpan.FromSeconds(5));
                        }
                    }
                };
                //服务停止事件
                server.Stopped += (sender, args) =>
                {

                };

                //客户端连接事件
                server.ClientConnected += (sender, args) =>
                {
                    var clientId = args.ClientId;
                };
                //客户端断开事件
                server.ClientDisconnected += (sender, args) =>
                {
                    var clientId = args.ClientId;
                };

            });
        }

    }

2.2.配置文件-appsetting.json
{
  "Logging": {
    "LogLevel": {
      "Default": "Warning"
    }
  },
  "AllowedHosts": "*",
  "MqttOption": {
    "HostIp": "127.0.0.1",
    "HostPort": 61613,
    "Timeout": 5000,
    "UserName": "admin",
    "Password": "passwod"
  }
}
2.3.程序入口-Program.cs
    public class Program
    {
        public static void Main(string[] args)
        {
            CreateWebHostBuilder(args).Build().Run();
            //上述方法与下方注释代码效果一致
            //WebHost
            //    .CreateDefaultBuilder(args)
            //    .UseKestrel()
            //    .UseStartup<Startup>()
            //    .Build()
            //    .Run();
        }

        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseKestrel(o =>
                {
                    o.ListenAnyIP(61613, m => m.UseMqtt());//绑定MQTT服务端口
                    //o.ListenAnyIP(5000);
                })
                .UseStartup<Startup>();
    }

3.在API接口中使用MQTT服务

由于ASP.NET Core使用依赖注入(Dependency Injection)来实现控制反转(IoC),MQTTServer正是通过依赖注入添加到应用程序的服务集合中去,同样通过ASP.NET Core中的机制可以在API控制器类中获取当前实例中的MQTT服务。具体实现要借助接口IServiceProvider。创建一个辅助类如下:

    public static class ServiceLocator
    {
        public static IServiceProvider Instance { get; set; }
    }

在Startup类的Configure方法中添加如下代码:

//获取当前应用的服务集合
ServiceLocator.Instance = app.ApplicationServices;

在API控制器中就可以通过ServiceLocator获取服务并使用了。

    [Route("v1/api/values")]
    [ApiController]
    public class ValuesController : RootController
    {

        public string Test()
        {
            string result = "";
            //从服务集合中获取MQTT服务
            var service = ServiceLocator.Instance.GetService(typeof(MQTTnet.Server.MqttServer));
            var messager = (MQTTnet.Server.MqttServer)service;
            
            //这里你可以构建消息并发布

            return result;
        }
    }

示例代码

经过上述过程中的探索研究,虽然暂未实现图形化界面,但基本了解了如何使用ASP.NET Core构建MQTT代理服务器,同时掌握了在API接口中使用MQTT服务的方法,后续将做更深一步的研究。

### 回答1: paho.mqtt.cpp-master是一个用于C++编程语言的MQTT客户端库。它提供了一种方便的方式来连接到MQTT服务器,并与其进行通信。 使用paho.mqtt.cpp-master,您需要首先将该库添加到您的项目中。可以从GitHub上的paho.mqtt.cpp的存储库下载最新版本。下载并解压缩后,将库的文件夹拷贝到您的项目目录中。 然后,在您的C++代码中,您需要包含所需的库文件。您可以使用以下语句包含MQTT客户端头文件: ```cpp #include <mqtt/client.h> ``` 一旦包含了头文件,您可以创建MQTT客户端并连接到服务器。首先,您需要创建一个客户端对象: ```cpp mqtt::client client(YOUR_BROKER_ADDRESS, CLIENT_ID); ``` 在创建客户端对象时,您需要传入代表MQTT服务器的地址和一个唯一的客户端ID。然后,您可以设置一些连接选项,例如用户名和密码: ```cpp mqtt::connect_options connOpts; connOpts.set_keep_alive_interval(20); connOpts.set_clean_session(true); connOpts.set_user_name("YOUR_USERNAME"); connOpts.set_password("YOUR_PASSWORD"); ``` 接下来,您需要连接到服务器: ```cpp client.connect(connOpts); ``` 一旦连接成功,您便可以订阅主题、发布消息或接收消息。例如,要订阅一个主题,可以使用以下代码: ```cpp mqtt::topic topic = client.get_topic("YOUR_TOPIC"); topic.subscribe(); ``` 要发布一个消息到指定的主题,使用以下代码: ```cpp mqtt::message msg = mqtt::message::create("YOUR_MESSAGE"); topic.publish(msg); ``` 要接收来自服务器的消息,您需要创建一个回调函数,并将其与主题相关联: ```cpp void message_callback(mqtt::const_message_ptr msg) { std::cout << "Received message: " << msg->to_string() << std::endl; } topic.set_callback(message_callback); ``` 这是一个基本的使用示例。您可以根据自己的需求自定义更多功能,例如处理连接丢失、设置QoS等。 总而言之,paho.mqtt.cpp-master是一个强大而易于使用MQTT客户端库,提供了连接、发布、订阅和接收MQTT消息的功能,帮助您与MQTT服务器进行通信。 ### 回答2: paho.mqtt.cpp-master是一个基于C++语言的MQTT协议客户端库,用于在物联网应用中进行消息传输和通信。它是paho.mqtt.c库的C++版本实现,提供了一系列的函数和类来简化开发者使用MQTT协议进行通信的过程。 使用paho.mqtt.cpp-master需要进行以下步骤: 1.下载与安装库文件:可以从GitHub等代码托管平台下载paho.mqtt.cpp-master的源代码,并按照提供的安装文档进行编译和安装。安装成功后,将生成的库文件链接到自己的应用程序中。 2.添加头文件和命名空间:在自己的代码中添加正确的头文件引用,以及使用paho::mqtt命名空间。 3.创建MQTT客户端:使用paho.mqtt.cpp提供的类,如mqtt::async_client,来创建MQTT客户端。可以设置客户端的连接参数、消息回调函数等。 4.连接到MQTT代理服务器使用客户端对象的connect方法连接到MQTT代理服务器,需要设置服务器地址、端口号、用户名、密码等信息。连接成功后,可以开始发送和接收消息。 5.订阅主题和接收消息:使用客户端对象的subscribe方法订阅感兴趣的主题。当有新消息到达时,会触发预先设置的消息回调函数,可以在回调函数中处理接收到的消息。 6.发布消息:使用客户端对象的publish方法发布消息。需要设置要发布的主题和消息内容,也可以设置其他的发布参数。 7.断开连接和清理资源:使用客户端对象的disconnect方法断开与MQTT代理服务器的连接,并释放相关的资源。 通过以上步骤,我们可以使用paho.mqtt.cpp-master库实现基于MQTT协议的消息传输和通信功能。由于该库提供了C++语言的接口和封装,开发者可以使用更为面向对象的方式进行开发,简化了编程过程和代码逻辑。同时,paho.mqtt.cpp-master也提供了一些示例代码和详细的文档,供开发者参考和学习。 ### 回答3: paho.mqtt.cpp-master是一个开源的C++ MQTT客户端库,用于通过MQTT协议与MQTT代理(broker)通信。以下是关于paho.mqtt.cpp-master的一些使用说明: 1. 安装:首先需要从GitHub上下载paho.mqtt.cpp-master的源代码。然后按照项目中的安装指南,使用CMake来构建和编译库文件。 2. 创建客户端:使用paho.mqtt.cpp-master,可以通过创建mqtt::client对象来创建一个MQTT客户端。在创建客户端时,需要传入MQTT代理的地址和端口号,以便让客户端能够与代理建立连接。 3. 连接到代理:使用mqtt::client对象的connect()函数可以将客户端连接到MQTT代理。在连接时,可以指定客户端的ID、用户名、密码等信息。连接成功后,客户端将能够发送和接收消息。 4. 发布消息:使用mqtt::client对象的publish()函数可以向MQTT代理发布消息。在发布时,需要指定主题(topic)和消息的内容。代理将会将消息发送给所有订阅了该主题的客户端。 5. 订阅主题:使用mqtt::client对象的subscribe()函数可以订阅MQTT代理上的主题。订阅成功后,当有新消息发布到该主题时,客户端将能够收到代理发送的消息。 6. 断开连接:使用mqtt::client对象的disconnect()函数可以断开客户端与MQTT代理的连接。在断开连接后,客户端将无法发送和接收消息。 paho.mqtt.cpp-master提供了一种方便的方式来使用MQTT协议进行通信。通过该库,开发者可以轻松地创建MQTT客户端,并与MQTT代理进行连接、发布消息和订阅主题等操作。同时,paho.mqtt.cpp-master还提供了一些其他功能和特性,例如TLS/SSL加密通信、持久会话等,可以根据实际需求进行配置和使用
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值