在花了 6 个小时尝试不同的方法来解决问题后,我总是得到同样的错误,并且无法弄清楚原因。
问题很容易理解:我在Appcelerator Titanium ACS中保存了10个用户,我想创建10条记录,每个用户一条。
这些东西必须很简单:所有用户都有相同的通行证,所以我只需要登录每个人,以用户身份创建对象,仅此而已!!(在 ACS 中,对象由创建对象的用户拥有(并user_id自动分配)。
为了管理异步,我使用带有回调的函数来等待结束。
var Cloud = require('ti.cloud');
function createObject(value, onComplete) {
Cloud.Objects.create({
classname: 'MyObj',
session_id: Cloud.sessionId,
fields: {
value: value
}
}, function(data) {
if (data.success) {
Ti.API.info('New value: user [' + data.Scores[0].user_id + '] - value: ' + data.Scores[0].value);
onComplete(true);
} else {
Ti.API.info('Error: ' + data.message);
onComplete(false);
}
});
}
function login(user, onComplete) {
Cloud.Users.login({
login: user.username,
password: '1234'
}, function(e) {
if (e.success) {
createObject(20, function(cb) {
onComplete(true);
});
} else {
Ti.API.warn('Error login user: ' + e.message);
onComplete(false);
}
});
}
// Get target users
Cloud.Users.query({
response_json_depth: 1
}, function(data) {
if (data.success) {
_.each(data.users, function(user) {
login(user, function(cb) {
Ti.API.warn("user: " + user.username);
});
});
}
});
好吧,我的结果总是相同的:
Ti.API.warn('user: ' + user.username);
显示正确的用户名(一个接一个),但Ti.API.info('New value: user [' + data.Scores[0].user_id + '] - value: ' + data.Scores[0].value);
始终显示相同的用户,这意味着为同一用户保存所有值(在数据库中签入,都是同一用户),而不是每个用户 1 个值。
我还尝试在 _.each 命令中使用异步,但结果相同。
问题出在哪里?我想我正在等待 _.每个用户的登录,登录必须等待才能完成 createObject,但似乎我做错了什么。
这里是出口。对我来说毫无意义...:
New value: user [54cb62cf18beba0935422a35] - value: 20
user: krusty
New value: user [54cb62cf18beba0935422a35] - value: 20
user: apu
New value: user [54cb62cf18beba0935422a35] - value: 20
user: ned
注意:所有呼叫保存的user_id对应于用户NED(最后一个)
这是ACS中的一个错误。无论如何,目前这并不重要,因为 5 年前就修复了。