- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在构建一个应用程序,登录用户可以通过按下按钮邀请另一个用户,因此受邀用户将收到推送通知。我的想法是,如果我可以将每个用户的 token 保存在数据库中,那么当用户按下“邀请按钮”时,它会发现数据库中的用户 token ,然后我会以某种方式使用它向那个发送通知用户。我不知道是否有更好的方法,但我没有找到其他任何东西,所以这是我目前的计划。
现在我遇到了一些关于如何将 token 保存到数据库的问题。每当用户创建帐户或 token 更改时,我都想将其保存到数据库中。
public class RegisterActivity extends AppCompatActivity {
private FirebaseAuth mAuth;
String username;
String password;
String age;
String email;
DatabaseReference mRootRef = FirebaseDatabase.getInstance().getReference();
DatabaseReference mRootPlayerBaseRef = mRootRef.child("Players");
private static final String TAG = "EmailPassword";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_register);
// [START initialize_auth]
// Initialize Firebase Authentication
mAuth = FirebaseAuth.getInstance();
// [END initialize_auth]
}
private void updateUI() {
Intent mainIntent = new Intent(RegisterActivity.this, LoginActivity.class);
mainIntent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
mainIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
startActivity(mainIntent);
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);
}
public void checkValues(View view) {
final EditText userEdit = (EditText) findViewById(R.id.username_field);
username = userEdit.getText().toString();
final EditText emailEdit = (EditText) findViewById(R.id.email_field);
email = emailEdit.getText().toString();
final EditText passwordEdit = (EditText) findViewById(R.id.password_field);
password = passwordEdit.getText().toString();
final EditText ageEdit = (EditText) findViewById(R.id.age_field);
age = ageEdit.getText().toString();
if (username.equals("") || email.equals("") || password.equals("") || age.equals("")){
Toast.makeText(RegisterActivity.this, "Please fill in all information", Toast.LENGTH_LONG).show();
return;}
if (username.length() < 4){
Toast.makeText(RegisterActivity.this, "Username has to be at least 4 characters", Toast.LENGTH_LONG).show();
return;
}
if (Integer.parseInt(age) < 5 || Integer.parseInt(age) > 120){
Toast.makeText(RegisterActivity.this, "Enter a valid age", Toast.LENGTH_LONG).show();
return;
}
//last thing to check is if username already exists
checkUsedUsername(username);
}
public void login(View view) {
Intent mainIntent = new Intent(RegisterActivity.this, LoginActivity.class);
startActivity(mainIntent);
overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);
}
public void checkUsedUsername(final String username){
mRootPlayerBaseRef.addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
//check if username exist otherwise create account
for (DataSnapshot data: dataSnapshot.getChildren()) {
if (username.equals(data.child("username").getValue())){
Toast.makeText(RegisterActivity.this, "Username already taken", Toast.LENGTH_LONG).show();
return;}
}
createAccount();
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
Toast.makeText(RegisterActivity.this, "Error", Toast.LENGTH_SHORT).show();
Toast.makeText(RegisterActivity.this, databaseError.getMessage(), Toast.LENGTH_SHORT).show();
}
});
}
private void createAccount(){
// [START create_user_with_email], built in function which checks if user can be created and insert it into auth database
mAuth.createUserWithEmailAndPassword(email, password)
.addOnCompleteListener(this, new OnCompleteListener<AuthResult>() {
@Override
public void onComplete(@NonNull Task<AuthResult> task) {
//if this was successful the user will now be in the database
if (task.isSuccessful()) {
//fetch the user
FirebaseUser user = mAuth.getCurrentUser();
//this set the created users getDisplayName() = username
UserProfileChangeRequest profileUpdates = new UserProfileChangeRequest.Builder()
.setDisplayName(username).build();
assert user != null;
user.updateProfile(profileUpdates);
//Here I would like to get the token so I can save it when a user is created
//get unique user id
String userID = user.getUid();
//create the user that will be inserted into the database
Player newPlayer = new Player(username, age, email);
//adding child(userID) will make we don´t replace previous user and actually insert new user, it becomes the key
mRootPlayerBaseRef.child(userID).setValue(newPlayer);
Toast.makeText(RegisterActivity.this, "Account was created successfully", Toast.LENGTH_LONG).show();
updateUI();
} else {
try
{
throw Objects.requireNonNull(task.getException());
}
// if user enters wrong email.
catch (FirebaseAuthWeakPasswordException weakPassword)
{
Log.d(TAG, "onComplete: weak_password");
Toast.makeText(RegisterActivity.this, "Password to weak", Toast.LENGTH_LONG).show();
}
// if user enters wrong password.
catch (FirebaseAuthInvalidCredentialsException malformedEmail)
{
Log.d(TAG, "onComplete: malformed_email");
Toast.makeText(RegisterActivity.this, "Wrong email", Toast.LENGTH_LONG).show();
}
catch (FirebaseAuthUserCollisionException existEmail)
{
Log.d(TAG, "onComplete: exist_email");
Toast.makeText(RegisterActivity.this, "Email already exists", Toast.LENGTH_LONG).show();
}
catch (Exception e)
{
Toast.makeText(RegisterActivity.this, "Error", Toast.LENGTH_SHORT).show();
Toast.makeText(RegisterActivity.this, "Please try again", Toast.LENGTH_SHORT).show();
}
}
}
});
// [END create_user_with_email]
}
}
public class MessagingService extends FirebaseMessagingService {
@Override
public void onNewToken(String s) {
super.onNewToken(s);
Log.d("NEW_TOKEN",s); //here we get the token so we can communicate with the database
}
//does not work as "Method does not override method from its superclass"
@Override
public void onTokenRefresh() {
super.onTokenRefresh();
}
}
我想要做的是将用户中的 token 与其他变量(如用户名、年龄等)一起保存在数据库中。
FirebaseAuth.getInstance().getCurrentUser().getIdToken(true) //this does not work
所以我真正要问的是如何为用户获取当前 token ?
最佳答案
Firebase 云消息传递 token 是 独有的。设备 ,而不是 用户 .它对 Firebase Auth 用户一无所知,Firebase Auth 对 FCM 设备 token 一无所知。
您将需要存储用户与其设备 token 的映射。由于用户可能使用多个设备,因此您的数据结构应该允许每个用户使用多个 token 。然后,您的后端代码应该查询这些 token 并将消息发送给每个 token (如果这是您的用户想要的)。
关于java - 如何获取当前用户的 Firebase token ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62799685/
在为 Web 应用程序用例图建模时,为用户可以拥有的每个角色创建一个角色是否更好?或拥有一个角色、用户和一个具有特权的矩阵? guest < 用户 < 版主 < 管理员 1: guest 、用户、版主
我无法使用 Elixir 连接到 Postgres: ** (Mix) The database for PhoenixChat.Repo couldn't be created: FATAL 28P
这个问题已经有答案了: Group by field name in Java (7 个回答) 已关闭 7 年前。 我必须编写一个需要 List 的方法并返回 Map> . User包含 Person
感谢您的帮助,首先我将显示代码: $dotaz = "Select * from customers JOIN contracts where customers.user_id ='".$_SESS
我只想向所有用户中的一个用户显示一个按钮。我尝试了 orderByKey() 但没有成功! 用户模型有 id 成员,我尝试使用 orderByChild("id") 但结果相同! 我什至尝试了以下技巧
我们在工作中从 MongoDB 切换到 Postgres,我正在建立一个 BDR 组。 在这一步,我正在考虑安全性并尽可能锁定。因此,我希望设置一个 replication 用户(角色)并让 BDR
export class UserListComponent implements OnInit{ users; constructor(private userService: UserS
我可以使用 Sonata User Bundle 将 FOS 包集成到 sonata Admin 包中。我的登录功能正常。现在我想添加 FOSUserBundle 中的更改密码等功能到 sonata
在 LinkedIn 中创建新应用程序时,我得到 4 个单独的代码: API key 秘钥 OAuth 用户 token OAuth 用户密码 我在 OAuth 流程中使用前两个。 的目的是什么?最后
所以..我几乎解决了所有问题。但现在我要处理另一个问题。我使用了这个连接字符串: SqlConnection con = new SqlConnection(@"Data Source=.\SQLEX
我有一组“用户”和一组“订单”。我想列出每个 user_id 的所有 order_id。 var users = { 0: { user_id: 111, us
我已经为我的Django应用创建了一个用户模型 class User(Model): """ The Authentication model. This contains the u
我被这个问题困住了,找不到解决方案。寻找一些方向。我正在用 laravel 开发一个新的项目,目前正致力于用户认证。我正在使用 Laravels 5.8 身份验证模块。 对密码恢复 View 做了一些
安装后我正在使用ansible配置几台计算机。 为此,我在机器上本地运行 ansible。安装中的“主要”用户通常具有不同的名称。我想将该用户用于诸如 become_user 之类的变量. “主要”用
我正在尝试制作一个运行 syncdb 的批处理文件来创建一个数据库文件,然后使用用户名“admin”和密码“admin”创建一个 super 用户。 到目前为止我的代码: python manage.
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我已在 Azure 数据库服务器上设置异地复制。 服务器上运行的数据库之一具有我通过 SSMS 创建的登录名和用户: https://learn.microsoft.com/en-us/azure/s
我有一个 ionic 2 应用程序,正在使用 native FB Login 来检索名称/图片并将其保存到 NativeStorage。流程是我打开WelcomePage、登录并保存数据。从那里,na
这是我的用户身份验证方法: def user_login(request): if request.method == 'POST': username = request.P
我试图获取来自特定用户的所有推文,但是当我迭代在模板中抛出推文时,我得到“User”对象不可迭代 观看次数 tweets = User.objects.get(username__iexact='us
我是一名优秀的程序员,十分优秀!