Xác thực với Firebase bằng tài khoản dựa trên mật khẩu trên Flutter

Bạn có thể sử dụng Xác thực Firebase để cho phép người dùng xác thực với Firebase bằng địa chỉ email và mật khẩu.

Trước khi bắt đầu

  1. Nếu bạn chưa làm theo, hãy làm theo các bước trong hướng dẫn Bắt đầu .

  2. Bật đăng nhập Email/Mật khẩu:

    • Trong phần Xác thực của bảng điều khiển Firebase, hãy mở trang Phương thức đăng nhập .
    • Từ trang Phương thức đăng nhập , bật phương thức đăng nhập Email/mật khẩu và nhấp vào Lưu .

Tạo tài khoản dựa trên mật khẩu

Để tạo tài khoản người dùng mới bằng mật khẩu, hãy gọi phương thức createUserWithEmailAndPassword() :

try {
  final credential = await FirebaseAuth.instance.createUserWithEmailAndPassword(
    email: emailAddress,
    password: password,
  );
} on FirebaseAuthException catch (e) {
  if (e.code == 'weak-password') {
    print('The password provided is too weak.');
  } else if (e.code == 'email-already-in-use') {
    print('The account already exists for that email.');
  }
} catch (e) {
  print(e);
}

Thông thường, bạn sẽ thực hiện việc này từ màn hình đăng ký ứng dụng của mình. Khi người dùng mới đăng ký bằng biểu mẫu đăng ký ứng dụng của bạn, hãy hoàn thành mọi bước xác thực tài khoản mới mà ứng dụng của bạn yêu cầu, chẳng hạn như xác minh rằng mật khẩu của tài khoản mới đã được nhập chính xác và đáp ứng các yêu cầu phức tạp của bạn.

Nếu tài khoản mới được tạo thành công, người dùng cũng đã đăng nhập. Nếu bạn đang lắng nghe những thay đổi trong trạng thái xác thực , một sự kiện mới sẽ được gửi tới người nghe của bạn.

Để tiếp nối quá trình tạo tài khoản mới, bạn có thể Xác minh địa chỉ email của người dùng .

Đăng nhập người dùng bằng địa chỉ email và mật khẩu

Các bước đăng nhập người dùng bằng mật khẩu tương tự như các bước tạo tài khoản mới. Từ màn hình đăng nhập của ứng dụng, hãy gọi signInWithEmailAndPassword() :

try {
  final credential = await FirebaseAuth.instance.signInWithEmailAndPassword(
    email: emailAddress,
    password: password
  );
} on FirebaseAuthException catch (e) {
  if (e.code == 'user-not-found') {
    print('No user found for that email.');
  } else if (e.code == 'wrong-password') {
    print('Wrong password provided for that user.');
  }
}

Bước tiếp theo

Sau khi người dùng tạo tài khoản mới, tài khoản này sẽ được lưu trữ như một phần của dự án Firebase của bạn và có thể được sử dụng để nhận dạng người dùng trên mọi ứng dụng trong dự án của bạn, bất kể người dùng đã sử dụng phương thức đăng nhập nào.

Trong ứng dụng của mình, bạn có thể lấy thông tin hồ sơ cơ bản của người dùng từ đối tượng User . Xem Quản lý người dùng .

Trong Quy tắc bảo mật cơ sở dữ liệu thời gian thực và lưu trữ đám mây của Firebase, bạn có thể lấy ID người dùng duy nhất của người dùng đã đăng nhập từ biến auth và sử dụng nó để kiểm soát dữ liệu nào người dùng có thể truy cập.

Bạn có thể cho phép người dùng đăng nhập vào ứng dụng của mình bằng nhiều nhà cung cấp xác thực bằng cách liên kết thông tin xác thực của nhà cung cấp xác thực ) với tài khoản người dùng hiện có.

Để đăng xuất người dùng, hãy gọi signOut() :

await FirebaseAuth.instance.signOut();