我计划创建一个名为users的主树,其中包含用户名不同的用户名。因此,从每个用户名中将包含他们的数据,例如姓名,地址,电话号码
我想知道如何在用户登录个人资料时获取每个用户的数据。
答案 0 :(得分:66)
首先,我建议您通过阅读Firebase Guide(Link to old Firebase Guide)来花些时间熟悉firebase。您可以在那里找到回答自己问题所需的一切。但为了简单起见,我将在这里举一个例子:
让我们从安全性开始,以下是此示例所需的基本firebase规则:(来源:Understanding Security)(旧来源:Understanding Security)
{
"rules": {
"users": {
"$user_id": {
".write": "$user_id === auth.uid"
}
}
}
}
我将跳过实际的用户创建和登录,并关注有关存储和检索用户数据的问题。
存储数据:(来源:Firebase Authentication)(旧来源:User Authentication)
// Get a reference to the database service
var database = firebase.database();
// save the user's profile into Firebase so we can list users,
// use them in Security and Firebase Rules, and show profiles
function writeUserData(userId, name, email, imageUrl) {
firebase.database().ref('users/' + userId).set({
username: name,
email: email
//some more user data
});
}
生成的firebase数据如下所示:
{
"users": {
"simplelogin:213": {
"username": "password",
"email": "bobtony"
},
"twitter:123": {
"username": "twitter",
"email": "Andrew Lee"
},
"facebook:456": {
"username": "facebook",
"email": "James Tamplin"
}
}
}
最后但并非最不重要的是数据的检索,这可以通过多种方式完成,但是对于这个例子,我将使用firebase指南中的一个简单示例:(来源:Read and Write data)(旧的来源) :Retreiving Data)
//Get the current userID
var userId = firebase.auth().currentUser.uid;
//Get the user data
return firebase.database().ref('/users/' + userId).once('value').then(function(snapshot) {
//Do something with your user data located in snapshot
});
编辑:添加了返回数据的示例
因此,当您以用户twitter:123登录时,您将根据您的用户ID获得对该位置的引用,并将获取此数据:
"twitter:123": {
"username": "twitter",
"email": "Andrew Lee"
}
答案 1 :(得分:1)
尽管我同意安德烈(Andre)制定的安全规则的规定-我对数据的处理会有所不同。我没有生成字符串,而是使用child()
方法。这是个人喜好问题。
获取UID并定义一个数据对象:
let user = firebase.auth().currentUser
let uid = user.uid
let yourdata = { foo: 'something', bar: 'other'}
保存数据:
firebase.database().ref('users').child(uid).set(yourdata)
.then((data) => {
console.log('Saved Data', data)
})
.catch((error) => {
console.log('Storing Error', error)
})
获取数据:
firebase.database().ref('users').child(uid).once('value')
.then((data) => {
let fetchedData = data.val()
console.log('Fetched Data', fetchedData)
})
.catch((error) => {
console.log('Fetching Error', error)
})
请注意,set()
将覆盖您的数据,因此您以后可能希望使用push()
。