我正在使用Firebase开发移动应用程序。在移动应用程序中,我需要根据他/她的手机号码注册用户,类似于Whatsapp。我打算使用Nexmo来验证用户的手机号码。验证号码涉及两个步骤。
我想使用firebase-queue来执行这些任务。我想询问是否有办法将任务的结果返回给客户端。我没有在firebase-queue文档中看到任何这样的示例。基本上,我想添加一个任务来将手机号码发送到Nexmo API,并希望得到request_id作为响应,以便我可以添加另一个任务来验证用户输入的代码。
答案 0 :(得分:7)
肯定有办法将回复反馈给客户。我们在Flashlight search integration:
中有一个很好的例子 function doSearch(index, type, query) {
var ref = new Firebase(URL+'/search');
var key = ref.child('request').push({ index: index, type: type, query: query }).key();
console.log('search', key, { index: index, type: type, query: query });
ref.child('response/'+key).on('value', showResults);
}
此代码在客户端JavaScript应用程序中运行,并在调用push()
的行中向服务器发送搜索词。然后等待"等待"对于回复函数的最后一行的响应。这里的关键是它通过用于发送请求的sam push id / key来侦听响应。这样请求和响应就匹配了。
虽然Firebase Queue没有内置支持此类"握手",但您可以轻松地将其自行构建到应用的客户端和服务器代码中。添加任务时,添加请求ID(来自the firebase-queue sample的适配器):
var request_id = ref.push().key();
ref.child('queue/tasks').push({ requestId: request_id, foo: 'bar' });
在任务工作者中,执行常规处理,然后使用相同的请求ID(来自firebase-queue sample的适配器)将响应写回数据库中:
var ref = new Firebase('https://<your-firebase>.firebaseio.com/queue');
var responses = new Firebase('https://<your-firebase>.firebaseio.com/responses');
var queue = new Queue(ref, function(data, progress, resolve, reject) {
// Read and process task data
console.log(data);
// Do some work
progress(50);
// Finish the task asynchronously
setTimeout(function() {
// write the response to the client
responses.child(data.requestId).set({ allDone: true });
// tell firebase-queue that we're done
resolve();
}, 1000);
});
答案 1 :(得分:2)
您无需在对象中编写requestId。相反,您可以使用以下代码返回响应。我认为它有点清洁。
在客户端: 。ref.child(&#39;队列/任务&#39)推动({FOO:&#39;杆&#39;});
诀窍是不对输入进行消毒。在服务器端:
var options = {sanitize:false};
queue = new Queue(firebaseQueueRef, options , function(request, progress, resolve, reject){
//do some work
setTimeout(function(){
resposeRef.child(request._id).set(myResponse);
resolve();
}
});