Getting Started
__CAPGO_KEEP_0__
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-firebase-storage`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/firebase-storage/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
설치, 동기화 및 소스 마크다운 가이드를 포함합니다.
설치bun add @capgo/capacitor-firebase-storagebunx cap sync클립보드 복사하기
__CAPGO_KEEP_0__ importimport { FirebaseStorage } from '@capgo/capacitor-firebase-storage';API 개요
API 개요deleteFile
__CAPGO_KEEP_0__ 삭제파일 삭제.
import { FirebaseStorage } from '@capgo/capacitor-firebase-storage';
await FirebaseStorage.deleteFile({} as DeleteFileOptions);getDownloadUrl
__CAPGO_KEEP_0__ 다운로드 URL 가져오기__CAPGO_KEEP_0__ 다운로드 URL 복사
import { FirebaseStorage } from '@capgo/capacitor-firebase-storage';
await FirebaseStorage.getDownloadUrl({} as GetDownloadUrlOptions);getMetadata
__CAPGO_KEEP_0__ 파일 메타데이터 복사__CAPGO_KEEP_0__ 파일 메타데이터 가져오기
import { FirebaseStorage } from '@capgo/capacitor-firebase-storage';
await FirebaseStorage.getMetadata({} as GetMetadataOptions);listFiles
__CAPGO_KEEP_1__ 폴더 목록폴더 내 파일 목록을 표시합니다.
import { FirebaseStorage } from '@capgo/capacitor-firebase-storage';
await FirebaseStorage.listFiles({} as ListFilesOptions);updateMetadata
__CAPGO_KEEP_1__ 파일 메타데이터 업데이트파일의 메타데이터를 업데이트합니다.
import { FirebaseStorage } from '@capgo/capacitor-firebase-storage';
await FirebaseStorage.updateMetadata({} as UpdateMetadataOptions);uploadFile
__CAPGO_KEEP_1__ 파일 업로드파일을 업로드합니다.
import { FirebaseStorage } from '@capgo/capacitor-firebase-storage';
await FirebaseStorage.uploadFile({} as UploadFileOptions, {} as UploadFileCallback);useEmulator
__CAPGO_KEEP_1__ Cloud Storage 에뮬레이터와 통신하기앱을 Cloud Storage 에뮬레이터와 통신하도록 구성합니다.
안드로이드에서 텍스트 전송은 허용되어야 합니다. Capacitor 설정에서:
{ server: { cleartext: true }}생산 환경에서 사용하지 않는 텍스트 전송입니다.
import { FirebaseStorage } from '@capgo/capacitor-firebase-storage';
await FirebaseStorage.useEmulator({} as UseEmulatorOptions);타입 참조
타입 참조 - '타입 참조'DeleteFileOptions
타입 참조 - 'DeleteFileOptions'export interface DeleteFileOptions { /** * The full path to the file to delete, including the file name. * * @since 5.3.0 * @example 'mountains.png' * @example 'images/mountains.png' */ path: string;}GetDownloadUrlOptions
타입 참조 - 'GetDownloadUrlOptions'export interface GetDownloadUrlOptions { /** * The full path to the file to get the download url for, including the file name. * * @since 5.3.0 * @example 'mountains.png' * @example 'images/mountains.png' */ path: string;}GetDownloadUrlResult
타입 참조 - 'GetDownloadUrlResult'export interface GetDownloadUrlResult { /** * The download url for the file. * * @since 5.3.0 */ downloadUrl: string;}GetMetadataOptions
GetMetadataOptionsexport interface GetMetadataOptions { /** * The full path to the file to get the metadata for, including the file name. * * @since 5.3.0 * @example 'mountains.png' * @example 'images/mountains.png' */ path: string;}GetMetadataResult
GetMetadataResultexport interface GetMetadataResult { /** * The bucket this file is contained in. * * @since 5.3.0 */ bucket: string; /** * The timestamp at which the file was created in milliseconds since the epoch. * * @since 5.3.0 * @example 1697304435933 */ createdAt?: number; /** * The object's generation. * * @since 5.3.0 * @see https://cloud.google.com/storage/docs/metadata#generation-number */ generation: string; /** * The md5 hash of the file. * * @since 5.3.0 */ md5Hash?: string; /** * The object's metadata generation. * * @since 5.3.0 * @see https://cloud.google.com/storage/docs/metadata#generation-number */ metadataGeneration: string; /** * The short name of this file, which is the last component of the full path. * * @since 5.3.0 * @example 'mountains.png' */ name?: string; /** * The full path to the file, including the file name. * * @since 5.3.0 * @example 'images/mountains.png' */ path?: string; /** * The size of the file in bytes. * * @since 5.3.0 */ size: number; /** * The timestamp at which the file was last updated in milliseconds since the epoch. * * @since 5.3.0 * @example 1697304435933 */ updatedAt: number; /** * Served as the `Cache-Control` header on object download. * * @since 6.1.0 */ cacheControl?: string; /** * Served as the `Content-Disposition` header on object download. * * @since 6.1.0 */ contentDisposition?: string; /** * Served as the `Content-Encoding` header on object download. * * @since 6.1.0 */ contentEncoding?: string; /** * Served as the `Content-Language` header on object download. * * @since 6.1.0 */ contentLanguage?: string; /** * Served as the `Content-Type` header on object download. * * @since 6.1.0 */ contentType?: string; /** * Additional user-defined custom metadata. * * @since 6.1.0 */ customMetadata?: { [key: string]: string };}ListFilesOptions
ListFilesOptionsexport interface ListFilesOptions { /** * The full path to the directory to list files for. * * @since 5.3.0 */ path: string; /** * The maximum number of results to return. * * @since 5.3.0 * @default 1000 */ maxResults?: number; /** * The page token, returned by a previous call to this method. * If provided, listing is resumed from the previous position. * * @since 5.3.0 */ pageToken?: string;}ListFilesResult
ListFilesResultexport interface ListFilesResult { /** * The list of files in the directory. * * @since 5.3.0 */ items: StorageReference[]; /** * If set, there might be more results for this list. * Use this token to resume the list. * * @since 5.3.0 */ nextPageToken?: string;}UpdateMetadataOptions
UpdateMetadataOptionsexport interface UpdateMetadataOptions { /** * The full path to the file to update the metadata for, including the file name. * * @since 5.3.0 */ path: string; /** * The metadata to update. * * @since 5.3.0 */ metadata: SettableMetadata;}UploadFileOptions
UploadFileOptionsexport interface UploadFileOptions { /** * The data to upload. * * Only available for Web. * * @since 5.3.0 */ blob?: Blob; /** * The full path where data should be uploaded, including the file name. * * @since 5.3.0 * @example 'mountains.png' * @example 'images/mountains.png' */ path: string; /** * The uri to the file to upload. * * Only available for Android and iOS. * * @since 5.3.0 * @example 'content://com.google.android.apps.photos.contentprovider/-1/1/content://media/external/images/media/1000000214/ORIGINAL/NONE/image/.png/mountains' * @example 'file:///var/mobile/Containers/Data/Application/E397A70D-67E4-4258-236E-W1D9E12111D4/Library/Caches/092F8464-DE60-40B3-8A23-EB83160D9F9F/mountains.png' */ uri?: string; /** * The metadata to set for the file. * * @since 5.4.0 */ metadata?: UploadMetadata;}UploadFileCallback
업로드 파일 콜백export type UploadFileCallback = (event: UploadFileCallbackEvent | null, error: any) => void;CallbackId
콜백 IDexport type CallbackId = string;UseEmulatorOptions
이미터 사용 옵션export interface UseEmulatorOptions { /** * The emulator host without any port or scheme. * * Note when using a Android Emulator device: 10.0.2.2 is the special IP address to connect to the 'localhost' of the host computer. * * @since 6.1.0 * @example "127.0.0.1" */ host: string; /** * The emulator port. * * @since 6.1.0 * @default 9199 * @example 9199 */ port?: number;}실제 원본
실제 원본이 페이지는 플러그인의 src/definitions.tsAPI이 업스트림에서 변경될 때 다시 싱크를 실행하세요.
Getting Started에서 계속
Getting Started에서 계속storage 및 파일 처리를 계획하고 연결하려면 Getting Started storage 및 파일 처리를 계획하고 연결하려면 @capgo/capacitor-data-storage-sqlite storage 및 파일 처리를 계획하고 연결하려면 @capgo/capacitor-data-storage-sqlite storage 및 파일 처리를 계획하고 연결하려면 @capgo/capacitor-data-storage-sqlite storage 및 파일 처리를 계획하고 연결하려면 @capgo/capacitor-data-storage-sqlite @capgo/capacitor-file storage 및 파일 처리를 계획하고 연결하려면 @capgo/capacitor-file storage 및 파일 처리를 계획하고 연결하려면 @capgo/capacitor-file storage 및 파일 처리를 계획하고 연결하려면 @capgo/capacitor-file @capgo/capacitor-uploader @capgo/capacitor-업로더에 대한 구현 세부 정보입니다.