0

如果数据库中存在 facebook id,我尝试创建数据,否则创建新数据,但是第一个条件工作正常,但是当它创建数据时没有任何反应,connot read property 'provider' of null即使我硬编码提供程序值也只能得到。

db.collection('accounts', function(err, collection){
    collection.findOne({'email': fbEmail}, function(err, item){
        var providerId = item.provider.facebook.id;
        console.log("facebook id should be: "+providerId);
        if(providerId == ""){
            collection.update({email:fbEmail, 'provider.facebook.id':""}, {$set: {"provider.facebook.id": fbId}}, {safe:true}, function(err){
                if(err){
                    console.log(err);
                }else{
                    console.log("id updated!");
                };
            });
        }else{ //creates a new user
            console.log("creating a new account...");
            collection.update({'email': fbEmail}, {
                'email': fbEmail,
                'provider':
                    {
                        'facebook': {'id': fbId},                            
                        'twitter': {'id': ""}                                
                    }                    
            }, {upsert:true}, function(err, doc){
                if(err){
                    console.log("Error finding email "+err);
                }                
            });             
        }
    });
});
4

1 回答 1

1

一个(第一个)accounts集合文件有provider=null. findOne您可以通过以下方式修改条件以避免它:

collection.findOne({'email': fbEmail, 'provider': {$exists: true}}, ...

请注意,此修改将跳过所有未provider设置字段(或设置为null)的帐户。

于 2013-01-23T16:55:21.943 回答