투케이2K

742. (Android/Java) [Firebase Storage] 파이어베이스 스토리지 에 저장 된 특정 파일 다운로드 URL 주소 확인 - File DownLoad Url 본문

Android

742. (Android/Java) [Firebase Storage] 파이어베이스 스토리지 에 저장 된 특정 파일 다운로드 URL 주소 확인 - File DownLoad Url

투케이2K 2024. 3. 7. 19:13

[개발 환경 설정]

개발 툴 : AndroidStudio

 
 

[소스 코드]

public class C_FirebaseStorageService {


    /**
     * // --------------------------------------------------------------------------------------
     * TODO [클래스 설명]
     * // --------------------------------------------------------------------------------------
     * 1. 파이어베이스 Storage 스토리지 관리 클래스
     * // --------------------------------------------------------------------------------------
     * 2. 참고 사이트 (기본 Storage 설명) : https://firebase.google.com/docs/storage?hl=ko&_gl=1*1ylydtb*_up*MQ..*_ga*MTk1MzY3OTg4OS4xNzA5NzkyODU1*_ga_CW55HF8NVT*MTcwOTc5Mjg1NS4xLjAuMTcwOTc5Mjg1NS4wLjAuMA..
     * // --------------------------------------------------------------------------------------
     * 3. 참고 사이트 (Storage 비용 설명) : https://firebase.google.com/pricing?hl=ko
     * // --------------------------------------------------------------------------------------
     * 4. 참고 사이트 (Storage 생성 방법) : https://blog.naver.com/kkh0977/223376155889
     * // --------------------------------------------------------------------------------------
     * 5. TODO 서비스 적용 방법 :
     *
     *   - 안드로이드에서 사전 파일 외부 저장소 접근 파일 읽기, 쓰기 권한 필요
     *   - 파이베이스 콘솔 프로젝트 생성
     *   - googole.json 파일 프로젝트에 추가
     *   - 구글 서비스 의존성 추가 (bom:32.3.1)
     *      : implementation 'com.google.firebase:firebase-storage:20.2.1' // [Storage]
     * // --------------------------------------------------------------------------------------
     * */





    // -----------------------------------------------------------------------------------------
    // TODO [전역 변수 선언]
    // -----------------------------------------------------------------------------------------
    private static final String ACTIVITY_NAME = "C_FirebaseStorageService";





    // -----------------------------------------------------------------------------------------
    // TODO [SEARCH FAST] : [Observable] : [File DownLoad Url] : 특정 파일 다운 로드 URL 확인
    // -----------------------------------------------------------------------------------------
    // TODO [호출 방법 소스 코드]
    // -----------------------------------------------------------------------------------------
    /*
    try {
        // [파이어베이스 저장소 경로 및 명칭 지정]
        String filePath = "/";
        String fileName = "DEBUG_LOG.txt";

        // [팝업창 활성 수행]
        C_FirebaseStorageService.observableFileDownUrl(A_Webview.this, filePath, fileName)
                .subscribeOn(AndroidSchedulers.mainThread()) // [Observable (생성자) 로직을 IO 스레드에서 실행 : 백그라운드]
                .observeOn(Schedulers.io()) // [Observer (관찰자) 로직을 메인 스레드에서 실행]
                .subscribe(new Observer<String>() { // [Observable.create 타입 지정]
                    @Override
                    public void onSubscribe(@NonNull Disposable d) {
                    }
                    @Override
                    public void onNext(@NonNull String value) {
                    }
                    @Override
                    public void onError(@NonNull Throwable e) {
                    }
                    @Override
                    public void onComplete() {
                    }
                });
    }
    catch (Exception e){
        e.printStackTrace();
    }
    */
    // -----------------------------------------------------------------------------------------
    public static Observable<String> observableFileDownUrl(Context mContext, String filePath, String fileName){

        // [로직 처리 실시]

        return Observable.create(subscriber -> {

            try {
                S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 확인", new String[]{ "filePath :: " + String.valueOf(filePath), "fileName :: " + String.valueOf(fileName) });

                // [방어 로직] : 널 체크
                if (C_Util.stringNotNull(filePath) == true){

                    FirebaseStorage storage = FirebaseStorage.getInstance(); // [인스턴스 생성]

                    StorageReference storageReference = storage.getReference(); // [Storage 저장 장소 지정]
                    StorageReference riversRef = storageReference.child(filePath);

                    // [파이어베이스에 저장된 파일 확인]
                    riversRef.listAll().addOnFailureListener(new OnFailureListener() {
                        @Override
                        public void onFailure(@NonNull Exception e) {
                            S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 확인 에러", new String[]{ "Firebase Get File List :: " + String.valueOf(e.getMessage()) });

                            subscriber.onNext("");
                            subscriber.onComplete();
                        }
                    }).addOnSuccessListener(new OnSuccessListener<ListResult>() {
                        @Override
                        public void onSuccess(ListResult listResult) {
                            if (listResult != null && listResult.getItems().size() > 0){

                                boolean fileSearchFlag = false;
                                StorageReference search_item = null;

                                for (StorageReference item : listResult.getItems()) {
                                    if (String.valueOf(item.getName()).equals(fileName) == true){
                                        fileSearchFlag = true; // [플래그 값 변경]
                                        search_item = item; // [아이템 값 삽입]
                                        break;
                                    }
                                }

                                if (fileSearchFlag == true){ // [해당 파일 존재할 경우]

                                    search_item.getDownloadUrl().addOnFailureListener(new OnFailureListener() {
                                        @Override
                                        public void onFailure(@NonNull Exception e) {
                                            S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 확인 에러", new String[]{ "Firebase Get File Url :: " + String.valueOf(e.getMessage()) });

                                            subscriber.onNext("");
                                            subscriber.onComplete();
                                        }
                                    }).addOnSuccessListener(new OnSuccessListener<Uri>() {
                                        @Override
                                        public void onSuccess(Uri uri) {

                                            if (uri != null && uri.getEncodedPath().length()>0){

                                                String fileUrl = String.valueOf(uri.getEncodedPath());

                                                if (fileUrl.startsWith("http") == true && fileUrl.contains("firebase") == true){
                                                    S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 확인 성공 [1]", new String[]{ String.valueOf(fileUrl) });

                                                    subscriber.onNext(String.valueOf(fileUrl));
                                                    subscriber.onComplete();
                                                }
                                                else {
                                                    fileUrl = "https://firebasestorage.googleapis.com" + fileUrl;

                                                    S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 확인 성공 [2]", new String[]{ String.valueOf(fileUrl) });

                                                    subscriber.onNext(String.valueOf(fileUrl));
                                                    subscriber.onComplete();
                                                }
                                            }
                                            else {
                                                S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 찾을 수 없음", new String[]{ "Reason :: File Url Is Null" });

                                                subscriber.onNext("");
                                                subscriber.onComplete();
                                            }
                                        }
                                    });
                                }
                                else {
                                    S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 찾을 수 없음", new String[]{ "Reason :: File Search Not Found" });

                                    subscriber.onNext("");
                                    subscriber.onComplete();
                                }
                            }
                            else {
                                S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 목록 없음", new String[]{ "Reason :: listResult Is Null" });

                                subscriber.onNext("");
                                subscriber.onComplete();
                            }
                        }
                    });

                }
                else {
                    S_Log._F_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] 파일 다운 URL 확인 에러", new String[]{ "ERROR :: Input Data Is Null" });

                    subscriber.onNext("");
                    subscriber.onComplete();

                }

            } catch (final Exception e){
                S_Log._printStackTrace_(mContext, ACTIVITY_NAME + " : [Firebase] [Storage] [Exception]", null, e);

                // ------------------------------------------------------
                // TODO [리턴 데이터 반환]
                // ------------------------------------------------------
                try {
                    subscriber.onNext("");
                    subscriber.onComplete();
                }
                catch (Exception ex){
                    ex.printStackTrace();
                }
            }

        });
    }


} // TODO [클래스 종료]

[결과 출력]


반응형
Comments