Mosca认证与授权

认证与授权

借助Mosca,可以通过定义三个方法授权一个客户端:

  • authenticate
  • authorizePublish
  • authorizeSubscribe
这些方法可用于对特定客户端限制可获得的主题权限。下面是一个简单的的小例子,客户端在建链阶段发送用户名与密码,用户名会被保存起来,稍微使用(为验证是否特定的客户端可以为特定用户发布或者订阅)

// 若用户名与密码有效,接受链接
var authenticate = function(client, username, password, callback) {
  var authorized = (username === 'alice' && password.toString() === 'secret');
  if (authorized) client.user = username;
  callback(null, authorized);
}

// 授权为alice的客户端可以发布/users/alice,
// 从主题中取得用户名,并校验与授权用户一致
var authorizePublish = function(client, topic, payload, callback) {
  callback(null, client.user == topic.split('/')[1]);
}

// 授权为alice的客户端可以订阅/users/alice,
// 从主题中取得用户名,并校验与授权用户一致
var authorizeSubscribe = function(client, topic, callback) {
  callback(null, client.user == topic.split('/')[1]);
}

在这个逻辑下,授权为'alice'的某个用户将不能够发布到主题'users/bob'。既然已经有了认证方法,mosca可以如下配置:

var server = new mosca.Server(settings);
server.on('ready', setup);

function setup() {
  server.authenticate = authenticate;
  server.authorizePublish = authorizePublish;
  server.authorizeSubscribe = authorizeSubscribe;
}

嵌入式Mosca使用Mosca独立授权方法

如果在自己的应用程序中使用Mosca作为嵌入式代理,但是仍然想使用CLI 授权特性,像在 Mosca作为独立使用定义的那样,也许会像如下描述的那样来进行。
首先,从lib/cli.js文件中将loadAuthorizer()方法拷贝出来,因为该方法定义为私有方法,或者可以简单地像这样引用它:
var fs = require("fs");
var Authorizer = require("mosca/lib/authorizer");

function loadAuthorizer(program, cb) {
	if (program.credentials) {
	    fs.readFile(program.credentials, function(err, data) {
		    if (err) {
		        cb(err);
		        return;
		    }

		    var authorizer = new Authorizer();

		    try {
		        authorizer.users = JSON.parse(data);
		        cb(null, authorizer);
		    } catch(err) {
		        cb(err);
		    }
	    });
	} else {
	    cb(null, null);
	}
}

然后,在moscaSettings变量中将credentials设定加入进去,路径指向自己的证书文件

credentials: "config/mqtt_credentials.json"
最后,像这样在setup()方法中创建自己的授权方法:

function setup() {
	// 创建授权方法
	loadAuthorizer(moscaSettings, function(err, authorizer) {
	    if (err) {
		    // 此处处理异常
	    }

	    if (authorizer) {
		    server.authenticate = authorizer.authenticate;
		    server.authorizeSubscribe = authorizer.authorizeSubscribe;
		    server.authorizePublish = authorizer.authorizePublish;
	    }
	});

}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MQTT是一种轻量级的消息传输协议,常用于物联网设备之间的通信。MQTT服务器端的实现可以使用多种语言和框架,这里以使用Node.js和Mosca框架为例进行介绍。 Mosca是基于Node.js的MQTT服务器框架,支持多种协议版本和QoS等级。以下是Mosca的服务器端实现步骤: 1. 安装Mosca框架和相关依赖 ``` npm install mosca bunyan --save ``` 2. 创建一个MQTT服务器实例 ```javascript var mosca = require('mosca'); var settings = { port: 1883 // MQTT服务器监听的端口号 }; var server = new mosca.Server(settings); ``` 3. 监听MQTT客户端连接事件 ```javascript server.on('clientConnected', function(client) { console.log('Client connected: ', client.id); }); ``` 4. 监听MQTT客户端发布消息事件 ```javascript server.on('published', function(packet, client) { console.log('Published:', packet.payload.toString()); }); ``` 5. 监听MQTT客户端订阅事件 ```javascript server.on('subscribed', function(topic, client) { console.log('Client subscribed to:', topic); }); ``` 6. 监听MQTT客户端取消订阅事件 ```javascript server.on('unsubscribed', function(topic, client) { console.log('Client unsubscribed from:', topic); }); ``` 7. 监听MQTT客户端断开连接事件 ```javascript server.on('clientDisconnected', function(client) { console.log('Client disconnected:', client.id); }); ``` 以上是Mosca框架的基本使用方法,可以根据需要自定义添加其他事件监听器。 除了Mosca框架外,还有其他MQTT服务器的实现方式,例如使用Java语言编写的Eclipse Mosquitto和使用Go语言编写的Eclipse Paho等。不同的实现方式可能有所不同,但基本原理都是类似的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值