Làm quen với Cloud Storage trên Flutter

Cloud Storage cho Firebase cho phép bạn tải lên và chia sẻ nội dung do người dùng tạo, chẳng hạn như hình ảnh và video, cho phép bạn tạo nội dung đa phương tiện vào ứng dụng của mình. Dữ liệu của bạn được lưu trữ trong bộ chứa Google Cloud Storage – một giải pháp lưu trữ đối tượng có tỷ lệ exabyte với khả năng hoạt động cao và khả năng dự phòng trên toàn hệ thống. Cloud Storage cho Firebase cho phép bạn tải các tệp này lên một cách an toàn ngay từ thiết bị di động và trình duyệt web, dễ dàng xử lý các mạng không ổn định.

Trước khi bắt đầu

  1. Nếu bạn chưa hoàn tất, hãy nhớ hoàn tất hướng dẫn bắt đầu sử dụng ứng dụng Flutter. Chẳng hạn như:

    • Tạo dự án Firebase.

    • Cài đặt và khởi chạy SDK Firebase cho Flutter.

  2. Đảm bảo rằng dự án Firebase của bạn đang sử dụng Gói giá linh hoạt trả tiền theo mức dùng. Nếu bạn mới sử dụng Firebase và Google Cloud, hãy kiểm tra xem bạn có đủ điều kiện nhận khoản tín dụng 300 USD hay không.

Tạo bộ chứa mặc định trên Cloud Storage

  1. Trong ngăn điều hướng của bảng điều khiển Firebase, hãy chọn Bộ nhớ.

    Nếu dự án của bạn chưa sử dụng gói giá linh hoạt Blaze (thanh toán theo mức sử dụng), bạn sẽ được nhắc nâng cấp dự án.

  2. Nhấp vào Bắt đầu.

  3. Chọn một vị trí cho bộ chứa mặc định.

  4. Định cấu hình Firebase Security Rules cho bộ chứa mặc định. Trong quá trình phát triển, hãy cân nhắc thiết lập quy tắc cho quyền truy cập công khai.

  5. Nhấp vào Xong.

Giờ đây, bạn có thể xem bộ chứa trong thẻ Cloud Storage Tệp của bảng điều khiển Firebase. Định dạng tên bộ chứa mặc định là PROJECT_ID.firebasestorage.app.

Thiết lập quyền truy cập công khai

Cloud Storage cho Firebase cung cấp một ngôn ngữ quy tắc khai báo cho phép bạn xác định cách cấu trúc dữ liệu, cách lập chỉ mục dữ liệu và thời điểm có thể đọc và ghi dữ liệu. Theo mặc định, quyền đọc và ghi vào Bộ nhớ trên đám mây bị hạn chế nên chỉ những người dùng đã xác thực mới có thể đọc hoặc ghi dữ liệu. Để bắt đầu mà không cần thiết lập tính năng Xác thực Firebase, bạn có thể định cấu hình quy tắc cho quyền truy cập công khai.

Điều này khiến Cloud Storage mở cho mọi người, ngay cả những người không sử dụng ứng dụng của bạn. Vì vậy, hãy nhớ hạn chế lại Cloud Storage khi bạn thiết lập quy trình xác thực.

Thêm SDK Cloud Storage vào ứng dụng

  1. Từ thư mục gốc của dự án Flutter, hãy chạy lệnh sau để cài đặt trình bổ trợ:

    flutter pub add firebase_storage
    
  2. Sau khi hoàn tất, hãy tạo lại ứng dụng Flutter:

    flutter run
    
  3. Nhập trình bổ trợ vào mã Dart của bạn:

    import 'package:firebase_storage/firebase_storage.dart';
    

Thiết lập Cloud Storage

  1. Chạy flutterfire configure từ thư mục dự án Flutter. Thao tác này sẽ cập nhật tệp cấu hình Firebase (firebase_options.dart) trong cơ sở mã của ứng dụng để tệp này có tên của bộ chứa Cloud Storage mặc định.

  2. Truy cập vào bộ chứa Cloud Storage bằng cách tạo một thực thể của FirebaseStorage:

    final storage = FirebaseStorage.instance;
    
    // Alternatively, explicitly specify the bucket name URL.
    // final storage = FirebaseStorage.instanceFor(bucket: "gs://<var>BUCKET_NAME</var>");
    

Bạn đã sẵn sàng bắt đầu sử dụng Cloud Storage!

Bước tiếp theo? Tìm hiểu cách tạo tệp đối chiếu Cloud Storage.

Thiết lập nâng cao

Có một số trường hợp sử dụng cần thiết lập thêm:

Trường hợp sử dụng đầu tiên là hoàn hảo nếu bạn có người dùng trên khắp thế giới và muốn lưu trữ dữ liệu của họ ở gần họ. Ví dụ: bạn có thể tạo các bộ chứa ở Hoa Kỳ, Châu Âu và Châu Á để lưu trữ dữ liệu cho người dùng ở những khu vực đó nhằm giảm độ trễ.

Trường hợp sử dụng thứ hai là hữu ích nếu bạn có dữ liệu với nhiều kiểu truy cập. Ví dụ: bạn có thể thiết lập một bộ chứa nhiều khu vực hoặc bộ chứa theo khu vực để lưu trữ ảnh hoặc nội dung thường được truy cập khác, cũng như bộ chứa gần dòng hoặc bộ chứa dòng lạnh để lưu trữ bản sao lưu của người dùng hoặc nội dung khác không được truy cập thường xuyên.

Trong cả hai trường hợp sử dụng này, bạn nên sử dụng nhiều bộ chứa trên Cloud Storage.

Trường hợp sử dụng thứ ba là hữu ích nếu bạn đang tạo một ứng dụng, chẳng hạn như Google Drive, cho phép người dùng có nhiều tài khoản đăng nhập (ví dụ: một tài khoản cá nhân và một tài khoản công việc). Bạn có thể sử dụng một bản sao Ứng dụng Firebase tuỳ chỉnh để xác thực từng tài khoản bổ sung.

Sử dụng nhiều bộ chứa trong Cloud Storage

Nếu muốn sử dụng một bộ chứa Cloud Storage khác với bộ chứa mặc định được cung cấp ở trên, hoặc sử dụng nhiều bộ chứa Cloud Storage trong một ứng dụng, bạn có thể tạo một thực thể của FirebaseStorage tham chiếu đến bộ chứa tuỳ chỉnh:

// Get a non-default Storage bucket
final storage = FirebaseStorage.instanceFor(bucket: "gs://my-custom-bucket");

Làm việc với các bộ chứa đã nhập

Khi nhập một bộ chứa hiện có trong Cloud Storage vào Firebase, bạn sẽ phải cấp cho Firebase quyền truy cập vào các tệp này bằng công cụ gsutil có trong SDK Google Cloud:

gsutil -m acl ch -r -u service-PROJECT_NUMBER@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://YOUR-CLOUD-STORAGE-BUCKET

Bạn có thể tìm thấy số dự án của mình như mô tả trong phần giới thiệu về dự án Firebase.

Điều này không ảnh hưởng đến các bộ chứa mới tạo, vì các bộ chứa đó có chế độ kiểm soát quyền truy cập mặc định được đặt để cho phép Firebase. Đây là biện pháp tạm thời và sẽ tự động được thực hiện trong tương lai.

Sử dụng Ứng dụng Firebase tuỳ chỉnh

Nếu đang xây dựng một ứng dụng phức tạp hơn bằng cách sử dụng FirebaseApp tuỳ chỉnh, bạn có thể tạo một thực thể của FirebaseStorage được khởi chạy bằng ứng dụng đó:

// Use a non-default App
final storage = FirebaseStorage.instanceFor(app: customApp);

Các bước tiếp theo